Il mondo degli sviluppatori JavaScript è sicuramente il più colorito: non si smette mai di imparare e troviamo sempre novità, anche se a volte bisogna bisogna riuscire a distinguere una cosa interessante da una utile. Questo è il caso della keyword with, usata per creare un contesto in cui il runtime cerca di risolvere le variabili utilizzando prima l'argomento fornito all'interno del contersto. Vediamo un pratico esempio.
with (console) { log('Hello world!'); }
Sebbene questa funzionalità possa sembrare utile grazie alla sua capacità di isolare contesti di esecuzione del codice, va anche considerato che le performance del codice all'interno del contesto saranno sicuramente peggiori del solito, in quanto, per ogni operazione, dovrà verificare che non questa esista all'interno di console. L'utilizzo di with può inoltre portare a problemi di shadowing, nascondendo alcune variabili, o addirittura di sicurezza, come nello snippet seguente.
function getPow(num, exp) { with (Math) { return pow(num, exp); } } getPow(2, 5); //NaN
Il codice restituirà NaN, e per un semplice motivo: abbiamo definito un parametro in ingresso chiamato exp, ma nell'utilizzo di with abbiamo anche creato un contesto in cui JavaScript proverà a risolvere tutto verso Math. Quest aclasse contiene la funzione Math.exp e il codice che verrà eseguito è Math.pow(num, Math.exp()).
Oltretutto se in precedenza è stato definito un delegate custom per il metodo Math.num, verrà eseguita la funzione e non utilizzato il parametro, un grosso rischio per la sicurezza del nostro codice, tanto che anche la docuentazione (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/with) avverte a riguardo e ne sconsiglia l'utilizzo.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ottimizzazione dei block template in Angular 17
Eseguire script pre e post esecuzione di un workflow di GitHub
Utilizzare DeepSeek R1 con Azure AI
Bloccare l'esecuzione di un pod in mancanza di un'artifact attestation di GitHub
Utilizzare l'espressione if inline in una pipeline di Azure DevOps
Selettore CSS :has() e i suoi casi d'uso avanzati
Gestire gli accessi con Token su Azure Container Registry
Estrarre dati randomici da una lista di oggetti in C#
Utilizzare il metodo ExceptBy per eseguire operazione di sottrazione tra liste
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Introduzione alle Container Queries