ES6 入门到精通(一)let 与 const 命令、模板字符串
文章目录
1 简介
ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。
ES6 既是一个历史名词,也是一个泛指,含义是 5.1 版以后的 JavaScript 的下一代标准,涵盖了 ES2015、ES2016、ES2017 等等,而 ES2015 则是正式名称,特指该年发布的正式版本的语言标准。提到 ES6 的地方,一般是指 ES2015 标准,但有时也是泛指“下一代 JavaScript 语言”。
2.1 var和let的区别
-
var有变量提升,let无变量提升
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let与const</title> </head> <body> </body> <script> // var 会变量提升,最后提示undifine,控制台不会报错 // var varNum; 变量自动提升后效果 console.log(varNum); var varNum = 15; // let 无变量提升,会在控制台报错 console.log(letNum); letNum = 20; </script> </html>
-
var非块级,let块级作用域
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let与const</title> </head> <body> </body> <script> // 控制台显示undifne不会报错,var作用域非块级,可以在块外部识别 console.log(varNum); if(true){ var varNum = 10; console.log(varNum); } // 控制台会报错,let作用域块级,无法在块外部识别 console.log(letNum); if(true){ let letNum = 10; console.log(letNum); } </script> </html>
-
var可以重复声明,let不允许重复声明
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let与const</title> </head> <body> </body> <script> // var可以重复声明,并且最后一次声明赋值会覆盖初始值。 var varNum = 10; var varNum = 5; // let不允许重复声明,控制台会报错,有些编译器也会直接提示报错。 let letNum = 30; let letNum = 15; </script> </html>
2.2 const 声明变量
在前端项目中最常用的就是const变量,很多第三方框架都会大量使用const保证框架源码不受污染,如Vue等。
-
const 声明的变量无变量提升、不允许重复声明、块级作用域,参考let
-
const 声明的变量不允许被修改
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let与const</title> </head> <body> </body> <script> // const声明的变量不允许修改,控制台会直接报错 const constNum = 10; constNum = 5; </script> </html>
-
const 声明的对象里的key value 可以被修改,对象不可修改
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>let与const</title> </head> <body> </body> <script> // const声明的对象里的key value可以被改变,对象本身不能改变 const constObject = {name:"张三"}; console.log("初始值:"+constObject.name); constObject.name = "李四" console.log("重新赋值:"+constObject.name); // 无法重新声明对象 constObject = {newName:"王五"} </script> </html>
2.3 let 与const 命令总结
let:在使用for循环时,全部使用let替换掉var,因为let为块级作用域,不会因为变量提升等问题,造成循环出错问题。
使用let定义的变量,不会污染全局变量,造成变量值错乱。
const:框架使用最多的变量,拥有let的特性(修改除外),不允许修改变量,允许修改对象里的keyvalue值,保证框架定义源码不受污染。
3.1 模板字符串
- 原字符串拼接代码可阅读性差
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>模板字符串</title>
</head>
<body>
<div class ="page">
<!-- 需要实现效果
<h1> 原字符串拼接 与 模板字符串比较 </h1>
<p>
<span>哈利</span>
<span>age</span>
</p>
-->
</div>
</body>
<script>
// 字符串拼接,代码可阅读性差
var page = document.querySelector('.page');
var title = '原字符串拼接'
var name = '哈利';
var age = 3;
page.innerHTML = "<h1>"+title+"</h1>"+"<p> <span> 姓名:"+name+"</span> <span> 年龄:"+age+"</span> </p>"
</script>
</html>
浏览器打开查看效果
- 使用 ES6 模板字符串代码可阅读性强
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>模板字符串</title>
</head>
<body>
<div class ="page">
<!-- 需要实现效果
<h1> 原字符串拼接 与 模板字符串比较 </h1>
<p>
<span>哈利</span>
<span>age</span>
</p>
-->
</div>
</body>
<script>
// ES6 模板字符串,代码可阅读性强,强烈推荐
const page = document.querySelector('.page');
let title = '模板字符串'
let name = '大将军';
let age = 28;
// 英文输入法下使用键盘 Tab键上的 ` 键
// 变量使用 ${} 包裹
page.innerHTML = `
<h1>${title}</h1>
<p>
<span>姓名:${name}</span>
<span>年龄:${age}</span>
</p>
`
</script>
</html>
浏览器打开查看效果
3.2 模板字符串总结
总结:从上述两个例子对比来看,建议以后在实际开发项目中,使用ES6的模板字符串语法,替换掉原来老式的字符串拼接,可以极大的提升代码的可读性