浅谈var、let、const

本文介绍了ECMAScript6中的块级作用域概念,对比了ES5与ES6在作用域上的差异。重点讨论了var、let和const的区别,强调了let如何限制变量的作用域,而const则用于定义不可变的常量。此外,还探讨了const定义的对象属性可以被修改,因为对象本身是引用类型的情况。
摘要由CSDN通过智能技术生成

本文属于转载文章
原文链接:https://blog.csdn.net/unionz/article/details/80032048

首先,一个常见的问题是,ECMAScript 和 JavaScript 到底是什么关系?

      ECMAScript是一个国际通过的标准化脚本语言。JavaScript由ECMAScript和DOM、BOM三者组成。可以简单理解为:ECMAScript是JavaScript的语言规范,JavaScript是ECMAScript的实现和扩展。

        2011 年,ECMAScript 5.1 版发布。之前我们大部分人用的也就是ES5

        2015 年 6 月,ECMAScript 6 正式通过,成为国际标准。

 

1. 块级作用域 {}

        ES5 中作用域有:全局作用域、函数作用域。没有块作用域的概念。

         ES6 中新增了块级作用域。块作用域由 { } 包括,if语句和 for语句里面的{ }也属于块作用域。


    
    
  1. <script type= "text/javascript">
  2. {
  3. var a = 1;
  4. console.log(a); // 1
  5. }
  6. console.log(a); // 1
  7. // 通过var定义的变量可以跨块作用域访问到。
  8. ( function A() {
  9. var b = 2;
  10. console.log(b); // 2
  11. })();
  12. // console.log(b); // 报错,
  13. // 可见,通过var定义的变量不能跨函数作用域访问到
  14. if( true) {
  15. var c = 3;
  16. }
  17. console.log(c); // 3
  18. for( var i = 0; i < 4; i ++) {
  19. var d = 5;
  20. };
  21. console.log(i); // 4 (循环结束i已经是4,所以此处i为4)
  22. console.log(d); // 5
  23. // if语句和for语句中用var定义的变量可以在外面访问到,
  24. // 可见,if语句和for语句属于块作用域,不属于函数作用域。
  25. </script>

 

 

2. var、let、const的区别

 

 

  1. var定义的变量,没有块的概念,可以跨块访问, 不能跨函数访问。
  2. let定义的变量,只能在块作用域里访问,不能跨块访问,也不能跨函数访问。
  3. const用来定义常量,使用时必须初始化(即必须赋值),只能在块作用域里访问,而且不能修改。

    
    
  1. <script type= "text/javascript">
  2. // 块作用域
  3. {
  4. var a = 1;
  5. let b = 2;
  6. const c = 3;
  7. // c = 4; // 报错
  8. var aa;
  9. let bb;
  10. // const cc; // 报错
  11. console.log(a); // 1
  12. console.log(b); // 2
  13. console.log(c); // 3
  14. console.log(aa); // undefined
  15. console.log(bb); // undefined
  16. }
  17. console.log(a); // 1
  18. // console.log(b); // 报错
  19. // console.log(c); // 报错
  20. // 函数作用域
  21. ( function A() {
  22. var d = 5;
  23. let e = 6;
  24. const f = 7;
  25. console.log(d); // 5
  26. console.log(e); // 6
  27. console.log(f); // 7
  28. })();
  29. // console.log(d); // 报错
  30. // console.log(e); // 报错
  31. // console.log(f); // 报错
  32. </script>

 

3. const定义的对象属性是否可以改变

这是今天面试的时候碰到的一个问题,上面说到 const 是不能修改的,于是很痛快的说不能,但是回来实际测试后发现错了,在此记录一下。


    
    
  1. const person = {
  2. name : 'jiuke',
  3. sex : '男'
  4. }
  5. person.name = 'test'
  6. console.log(person.name)

运行上述代码,发现person对象的name属性确实被修改了,这是怎么回事呢?

因为对象是引用类型的,person中保存的仅是对象的指针,这就意味着,const仅保证指针不发生改变,修改对象的属性不会改变对象的指针,所以是被允许的。也就是说const定义的引用类型只要指针不发生改变,其他的不论如何改变都是允许的。

然后我们试着修改一下指针,让person指向一个新对象,果然报错


    
    
  1. const person = {
  2. name : 'jiuke',
  3. sex : '男'
  4. }
  5. person = {
  6. name : 'test',
  7. sex : '男'
  8. }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值