作用域链&&严厉形式

作用域链

  1. 迷惑性代码
var a = 100;
function test(){
    console.log(a);
}
function testFun(){
    var a = 200;
    test();
}

不假思索的想到 出版的一定是 200啊 ,但是严严实实被打脸,输出 100

缘由

在编译时,

  1. 全局作用域中会存有的对象

    • a
    • test
    • testFun
  2. testFun作用域中存的

    • a
  3. test

在运行时,

test() 我这里须要变量a 啊,但是在test的作用域中并不存在,那末就须要去全局作用域中寻觅 a,报告老大找到了,输出全局作用域中的a,输出100

  1. 迷惑性代码
var a = 100;
function testFun2(){
    var a = 300;
    function test(){
        console.log(a)
    }
    test();
}
testFun2();

输出什么? 300!

?!为何呢

作用域链再走一波

1.全局作用域

    • a
    • testFun2
    1. testFun2

      • a
      • test
    2. test

    运行时test时,报告老大,我须要变量a ,test作用域:我没有啊,你去看看testFun2有无;
    testFun2作用域:我有 给你拿去好了;
    输出 300

    严厉形式

    实例

    'use strict';
    x = 3.14; //  报错(x 未定义)
    
    'use strict'
    myFunction();
    function myFunction(){
        y = 3.14;  //  报错 (y 未定义)
    }
    
    // 不允许删除变量或对象
    'use strict';
    var x = 3.14;
    delete x ;
    
    // 不允许删除函数
    'use strict';
    function x(p1,p2){};
    delete x ;
    //  报错
    // 不允许变量重名
    'use strict';
    function x(p1,p1){} //  报错 
    
    // 不允许运用八进制
    
    'use strict';
    var x = 010;   // 报错
    // 不允许运用转义字符
    'use strict';
    var x= \010;   // 报错
    //  不允许对只读属性赋值
    'use strict';
    var obj ={};
    Object.defineProperty(obj,'x',{value:0,writable:false});
    obj.x = 3.14;
    
    // 不允许对一个运用 getter要领读取的属性举行赋值
    'use strict';
    var obj ={get x(){return 0}};
    obj.x=3.14; //  报错
    
    // 变量名 不能运用 'eval'字符串
    'use strict';
    var eval = 3.14; //  报错
    //变量名不能运用 'arguments'字符串
    'use strict';
    var arguments = 3.14;  //报错
    // 制止 this 关键字指向全局对象
    
    function test(){
        console.log(this); // undefined
    }
    
    严厉形式新增的一些保存关键字
    • implements
    • interface
    • let
    • package
    • private
    • protected
    • public
    • static
    • yield
        原文作者:jdkwky
        原文地址: https://segmentfault.com/a/1190000013237556
        本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
    点赞