No conocía la existencia de let, la descubrí ayer porque había usado una variable llamada let en un artículo de 2011 que hablaba sobre cómo validar un DNI con javascript, y me comentaron «let es una palabra reservada«. Mi cara fue como ¿ein? ¿desde cuando? Así que me puse a buscar… y sí, desde la irrupción de ECMAScript 6 en junio de 2015 tenemos una palabra reservada para definir variables que es let, otra que es const para las constantes.
Sobre const no hay mucho que decir ya que el nombre es muy descriptivo: nos permite definir una constante. ¿Qué es una constante? Pues piensa en una variable pero que sólo puede recibir un valor en el momento de su declaración y que luego ya no puede ser modificada. Te pongo un ejemplo:
/*Declaramos PI como constante*/ const PI = 3.1415926; /*Esto daría error*/ PI = 3.1416; /*Porque no se puede volver a dar*/ /*valor a una constante*/
Vamos ahora con let, que tiene más chicha. Citando textualmente la documentación permite declarar variables limitando su alcance (scope) al bloque, declaración, o expresión donde se está usando. ¿Qué diferencia hay con var? Que var nos permite declarar una variable global o una variable local dentro de una función, pero no nos permite limitar su ámbito a un bloque de código concreto. Veamos un ejemplo:
/*Hagamos el ejemplo al viejo estilo*/ /*usando var*/ function PruebaVar() { var v = 45; if (true) { var v = 64; // es la misma variable console.log(v); // imprime 64 } console.log(v); // imprime 64 } /*vemos como el v de dentro del bloque y el de fuera son la misma variable. Si modificamos su valor dentro del bloque fuera también está modificado */ /*vamos con let*/ function PruebaLet() { let l = 45; if (true) { let l = 64; // diferente ámbito console.log(l); // imprime 64 } console.log(l); // imprime 45 } /*Con let en cambio la variable l de fuera del bloque y la de dentro son tomadas como variables diferentes, y cada una conserva el valor que se le dio en su ámbito.*/
El uso de let y const sólo está disponible en bloques envueltos en una etiqueta <script type="application/javascript;version=1.7">
o en una versión superior.