<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let</title> </head> <body> <script> //声明变量 let a; let b,c,d; let e = 100; let f = 521, g = 'iloveyou', h = []; //1. 变量不能重复声明 let star = '罗志祥'; let star = '小猪'; //2. 块儿级作用域 全局, 函数, eval // if else while for { let girl = '周扬青'; } console.log(girl); // 结果是girl is not defined ;let定义的只能在同一块级作用域内,这和var不同, //3. 不存在变量提升 就是说不允许在变量定义之前使用。 console.log(song); let song = '恋爱达人'; // 结果: song is not defined ;因为let不允许在变量定义之前使用。 // 如果是var的话,输出的结果就会是defined, //因为在执行 console.log(song)的时候他会默认自己创建一个var long;然后再执行 console.log(song); //4. 不影响作用域链 { let school = '尚硅谷'; function fn(){ console.log(school); } fn(); // 结果:尚硅谷 } </script> </body> </html>let 关键字 let 关键字用来声明变量,使用 let 声明的变量有几个特点: 1) 不允许重复声明 2) 块儿级作用域 3) 不存在变量提升 4) 不影响作用域链 应用场景:以后声明变量使用 let 就对了 标签:ES6,console,log,song,作用域,let,变量 From: https://www.cnblogs.com/anjingdian/p/16894424.html