Maison > interface Web > js tutoriel > Comment comprendre le levage de variables en JavaScript

Comment comprendre le levage de variables en JavaScript

清浅
Libérer: 2019-04-20 11:20:52
original
2862 Les gens l'ont consulté

La promotion des variables en JavaScript signifie que les déclarations de variables et de fonctions se déplaceront au début du code, mais en fait les positions des déclarations de variables et de fonctions ne bougeront pas, elles sont simplement placées en mémoire lors du processus de compilation .

Bien que JavaScript soit un langage interprété, une étape importante du développement Web avant l'exécution est que l'interpréteur parcourt le code et identifie toutes les variables déclarées, note quand elles sont réaffectées et divise les blocs de code en trois niveaux de portée : bloc, fonction et global. Ensuite, je présenterai en détail la promotion variable en JavaScript. J'espère que cela sera utile à tout le monde

Comment comprendre le levage de variables en JavaScript

[Cours recommandés : Tutoriel JavaScript

Exemple :

function exampleFunction() { 
 var x = "declared inside function";
 console.log("Inside function"); 
 console.log(x);
 }
 console.log(x);
Copier après la connexion
Rendu :


Comment comprendre le levage de variables en JavaScript

La portée de la fonction dans l'exemple ci-dessus inclut la variable x, donc la variable n'est connue que dans cette fonction. Si vous y accédez dans la portée globale, une erreur sera signalée car x n'est pas une variable déclarée.

Si vous déplacez la déclaration de x en dehors de la fonction, elle sera dans la portée globale et disponible à l'extérieur ou à l'intérieur de la fonction.

Exemple

var x = "declared outside function";
exampleFunction();
function exampleFunction() { 
 console.log("Inside function");
 console.log(x);}
 console.log("Outside function");
 console.log(x);
Copier après la connexion

Rendu :

Comment comprendre le levage de variables en JavaScript

Avec la sortie d'ES6 Apparaît, introduisant deux nouvelles méthodes de promotion de variables : les méthodes let et const. Ces méthodes fournissent un contrôle plus fin sur la plage disponible pour la variable. Les variables locales définies par let et const ne peuvent être utilisées que dans le niveau où elles sont définies

Promotion des variables

Dans l'exemple suivant, x déclare var , et x appelle la même variable dans toute la fonction et dans le sous-bloc. Si x est déclaré avec let ou const, alors la portée externe ne pourra pas y accéder, si nous déclarons à nouveau let x dans le sous-module ; en fait, il s'agit d'une variable différente

function varTest() { 
 var x = 1; 
 if (true) { 
   var x = 2;  
   console.log(x); // 2 
 }
 console.log(x); // 2 
 }
 function letTest() {
 let x = 1; 
 if (true) {
   let x = 2; 
   console.log(x); // 2
 }
 console.log(x); // 1}
Copier après la connexion

Exemple :

function doSomething() {
 console.log(bar); // undefined
 console.log(foo); // ReferenceError
 var bar = 1; 
 let foo = 2;}
Copier après la connexion
Dans cette fonction, la barre de déclaration est hissée en haut du scope. En fait, il s'exécute comme ceci :

function doSomething() {
 var bar;
 console.log(bar); // undefined
 console.log(foo); // ReferenceError
 bar = 1; 
 let foo = 2;}
Copier après la connexion
C'est pourquoi le résultat de console.log(bar) n'est pas défini, et console.log(foo) signalera une erreur

Cela fait comme ça Les choses sont possibles :

num = 6;
console.log(num); // returns 6
var num;
Copier après la connexion

et :

dogName("Watson");
function dogName(name) {
 console.log("My dog's name is " + name);
 }
Copier après la connexion
Dans le premier exemple, bien que le var num soit déclaré après l'affectation, depuis l'ordinateur Du point de vue, il remarque que nous l'avons déclaré globalement plus tôt, place la déclaration en haut et continue d'exécuter le reste du code. Dans le deuxième exemple, même si nous appelons/appelons la fonction avant de la définir, la définition est hissée en haut de la portée, donc au moment où nous commençons réellement à exécuter le code, l'interpréteur sait déjà de quoi il s'agit dogName() .

Remarque : Pour les variables var, seule la déclaration est levée, pas l'affectation.

Résumé : ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à tout le monde dans l'apprentissage de l'amélioration des variables.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal