Maison >interface Web >js tutoriel >Comprendre var, let et const en JS
Cet article vous présentera les var, let et const de JavaScript. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. L'instruction
var
est utilisée pour déclarer une variable en JavaScript, qui suit les règles suivantes :
window
avec le même nom. Lorsqu'elle est présente dans la portée globale, var
crée une variable globale. De plus, il crée une window
propriété globale sur avec le même nom :
var city = "Florence"; console.log(window.city); // "Florence"
Lorsqu'elle est déclarée dans une fonction, la variable est étendue à cette fonction :
var city = "Florence"; function bubble() { var city = "Siena"; console.log(city); } bubble(); // "Siena" console.log(city); // "Florence"
var
les déclarations sont levées :
function bubble() { city = "Siena"; console.log(city); var city; // hoists } bubble(); // "Siena"
Une variable affectée sans aucune déclaration (soit var
, let
ou const
) par défaut deviendra un variable globale :
function bubble() { city = "Siena"; console.log(window.city); } bubble(); // "Siena"
Pour éliminer ce comportement, utilisez le mode strict :
"use strict"; function bubble() { city = "Siena"; console.log(window.city); } bubble(); // ReferenceError: assignment to undeclared variable city
Toute variable déclarée avec var
peut ultérieurement être réaffecté ou redéclaré. Exemple de redéclaration :
function bubble() { var city = "Florence"; var city = "Siena"; console.log(city); } bubble(); // "Siena"
Exemple de réaffectation :
function bubble() { var city = "Siena"; city = "Florence"; console.log(city); } bubble(); // "Florence"
let
l'instruction déclare une variable en JavaScript qui obéit aux règles suivantes :
window
. Les variables déclarées avec let
ne créent aucune propriété globale sur window
:
let city = "Florence"; console.log(window.city); // undefined
lorsqu'elles sont déclarées à l'intérieur d'une fonction, la portée de la variable est la fonction :
let city = "Florence"; function bubble() { let city = "Siena"; console.log(city); } bubble(); // "Siena" console.log(city); // "Florence"
Lorsqu'elle est déclarée dans le bloc , la portée de la variable est le bloc. Voici un exemple d'utilisation au sein d'un bloc :
let city = "Florence"; { let city = "Siena"; console.log(city); // "Siena"; } console.log(city); // "Florence"
Un exemple avec un bloc if
:
let city = "Florence"; if (true) { let city = "Siena"; console.log(city); // "Siena"; } console.log(city); // "Florence"
En revanche, var
n'est pas restreint par un bloc :
var city = "Florence"; { var city = "Siena"; console.log(city); // "Siena"; } console.log(window.city); // "Siena"
let
peut être favorisée, mais générera une zone morte temporaire :
function bubble() { city = "Siena"; console.log(city); // TDZ let city; } bubble(); // ReferenceError: can't access lexical declaration 'city' before initialization
La zone morte temporaire peut empêcher l'initialisation Visite précédente let
Déclaration. Autre exemple :
function bubble() { console.log(city); // TDZ let city = "Siena"; } bubble(); // ReferenceError: can't access lexical declaration 'city' before initialization
Vous pouvez voir que les exceptions générées dans les deux exemples sont les mêmes : prouvant l'émergence d'une "zone morte temporaire".
Toute variable let
déclarée avec ne peut être redéclarée . Un exemple de redéclaration qui lève une exception :
function bubble() { let city = "Siena"; let city = "Florence"; console.log(city); } bubble(); // SyntaxError: redeclaration of let city
Voici un exemple de réallocation valide :
function bubble() { let city = "Siena"; city = "Florence"; console.log(city); } bubble(); // "Florence"
const
l'instruction est utilisée pour déclarer une variable en JavaScript, cette variable suit les règles suivantes :
window
. Les variables déclarées avec const ne créent aucune propriété globale sur window
:
const city = "Florence"; console.log(window.city); // undefined
Lorsqu'elle est déclarée dans une fonction, la variable La portée de est la fonction :
const city = "Florence"; function bubble() { const city = "Siena"; console.log(city); } bubble(); // "Siena" console.log(city); // "Florence"
Lorsqu'elle est déclarée dans un bloc, la portée de la variable est le bloc. Exemple d'instruction de blocage {}
:
const city = "Florence"; { const city = "Siena"; console.log(city); // "Siena"; } console.log(city); // "Florence"
Exemple d'instruction de blocage dans if
:
const city = "Florence"; if (true) { const city = "Siena"; console.log(city); // "Siena"; } console.log(city); // "Florence"
const
peut être levée, cependant, entrera dans la zone morte temporaire :
function bubble() { console.log(city); const city = "Siena"; } bubble(); // ReferenceError: can't access lexical declaration 'city' before initialization
Toute variable const
déclarée avec ne peut pas non plus être redéclarée. il soit réaffecté . Un exemple d'exception levée lors d'une redéclaration :
function bubble() { const city = "Siena"; const city = "Florence"; console.log(city); } bubble(); // SyntaxError: redeclaration of const city
Un exemple de réallocation :
function bubble() { const city = "Siena"; city = "Florence"; console.log(city); } bubble(); // TypeError: invalid assignment to const 'city'
Portée du bloc | Zone morte temporaire | Créer des propriétés globales | Réaffectable | Redéclarable | |||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
❌ | ❌ | ✅ | ✅ | ✅ | ||||||||||||||||||||||||
✅ | ✅ | ❌ | ✅ | ❌ | |||||||||||||||||||||||||
✅✅ | ❌ | ❌ | ❌ |
Anglais adresse originale : https://www.valentinog.com/blog/var/
Auteur : ValentinoRecommandations d'apprentissage gratuites connexes : Tutoriel vidéo js
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!