最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 从原理角度分析var let const的区别

    正文概述 掘金(Akii)   2021-05-30   532

    前言:本文主要从存储方式进行分析,如有错误感谢指教。

    一、存储方式

    1. var

      1.1 变量的值是原始值

      会在栈内存中预分配内存空间,当语句被执行时,会将变量存储到该内存空间。如下图所示:

      从原理角度分析var let const的区别

      1.2 变量的值是引用值

      会在堆内存里开辟一个内存空间存储实际值,在栈内存中会存储一个指向该堆内存的指针。如下图所示:

      从原理角度分析var let const的区别

    2. let

      不会在栈内存里预分配内存空间。执行语句时,会在栈内存做一个检查,如果已经有相同变量名存在就会报错。

    3. const

      不会在栈内存里预分配内存空间。执行语句时,和let相同,会在栈内存检查是否存在相同变量名,存在则报错。

      不过,const存储的变量是不可以修改的:

      3.1 如果变量值是原始值,则无法修改该变量的值;

      3.2 如果变量值是引用值,则无法修改栈内存里分配的指针,但是可以修改指针指向的对象里面的属性。

    可以看看下面的例子:

    var num1 = 10;
    var num1 = 20;
    console.log(num1);	// 20
    
    let num2 = 30;
    let num2 = 40;	// Uncaught SyntaxError: Identifier 'num2' has already been declared
    
    const num3 = 50;
    num3 = 60;	// Uncaught TypeError: Assignment to constant variable
    
    const obj1 = new Object();
    const obj2 = new Object();
    obj1 = obj2	// Uncaught TypeError: Assignment to constant variable
    
    obj1.num4 = 70;
    console.log(obj1.num4)	// 70
    

    二、区别

    1. 作用域

      1.1 使用var进行声明的变量,变量会自动添加到最接近的上下文。

      在函数中,最接近的上下文就是函数的局部上下文;在with语句中,最接近的上下文也是函数的局部上下文;如果变量未经声明就被初始化,则会被自动添加到全局上下文中。

      如以下例子所示:

      function add1(a, b) {
        var sum = a + b;
        return sum;
      }
      
      let result = add1(10, 20);
      console.log(result);	// 30
      
      function add2(a, b) {
        // 在这里不对sum进行声明,直接初始化
        sum = a + b
        return sum;
      }
      let result = add2(10, 20);
      console.log(result);	// 30
      console.log(sum);			// 30
      
      

      1.2 let的作用域是块级的。块级的作用域由最近的一对包含花括号{}界定。

      代码示例如下所示:

      while(true) {
        let a = 10
      }
      console.log(a)	// Uncaught ReferenceError: a is not defined
      
    2. 变量声明

      2.1 var声明会拿到函数或全局作用域的顶部,位于所有代码之前。声明的提升意味着会输出undefined而不是Reference Error,以下代码可以验证变量会被提升:

      console.log(name);	//undefined
      var name = 'aki';
      

      2.2 严格来讲,使用let声明变量时也会发生变量提升的现象,但由于存在“暂时性死区”,不能在声明之前以任何方式引用未声明的let变量。因此,从写JavaScript的角度说,let的提升和var的提升是不一样的。

      2.3 与var不同,使用let在全局作用域声明的变量不会被成为window对象的属性。

      var name = 'aki';
      console.log(window.name);  // 'aki'
      
      let age = 20;
      console.lof(window.age);  // undefined
      
    3. const常量声明

      使用const声明的变量必须同时进行初始化;const赋值的引用值变量不能再被重新赋值为其他引用值,但对象的键不受限制。

      const num1;	// SyntaxError
      num1 = 10;
      
      const num2 = 20;
      num2 = 200;	// TypeError
      

    起源地下载网 » 从原理角度分析var let const的区别

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元