ES6 入门到精通(一)let 与 const 命令、模板字符串

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的模板字符串语法,替换掉原来老式的字符串拼接,可以极大的提升代码的可读性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值