La différence est portée. var
est portée la plus proche de bloc de fonction (ou global si à l'extérieur d'un bloc de fonction), et let
est portée la plus proche enfermant bloc (ou global si à l'extérieur d'un bloc), qui peut être plus petite qu'un bloc de fonction.
Aussi, à l'instar var
, les variables déclarées avec let
sont visibles avant qu'ils ne soient déclarés dans leur bloc enfermant, comme montré dans la démo.
Démo: (Firefox Uniquement)
Mondial:
Ils sont identiques lorsqu'il est utilisé comme cela, en dehors d'un bloc de fonction.
let me = 'go'; //globally scoped
var i = 'able'; //globally scoped
Fonction:
Ils sont identiques lorsqu'il est utilisé comme cela, dans un bloc de fonction.
function ingWithinEstablishedParameters() {
let terOfRecommendation = 'awesome worker!'; //function block scoped
var sityCheerleading = 'go!'; //function block scoped
};
Bloc:
Là est la différence. let
n'est visible que dans l' for()
boucle et var
est visible à l'ensemble de la fonction.
function allyIlliterate() {
//tuce is *not* visible out here
for( let tuce = 0; tuce < 5; tuce++ ) {
//tuce is only visible in here (and in the for() parentheses)
};
//tuce is *not* visible out here
};
function byE40() {
//nish *is* visible out here
for( var nish = 0; nish < 5; nish++ ) {
//nish is visible to the whole function
};
//nish *is* visible out here
};
En outre:
let
peut également être utilisé pour créer son propre bloc enfermant.
function conjunctionJunctionWhatsYour() {
//sNotGetCrazy is *not* visible out here
let( sNotGetCrazy = 'now' ) {
//sNotGetCrazy is only visible in here
};
//sNotGetCrazy is *not* visible out here
};