作用域链&&严格模式

作者: jdkwky | 来源:发表于2018-02-09 14:55 被阅读0次

    作用域链

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

    不假思索的想到 输出的一定是 200啊 ,然而结结实实被打脸,输出 100

    原因

    在编译时,

    1. 全局作用域中会存有的对象
    • a
    • test
    • testFun
    1. testFun作用域中存的
    • a
    1. 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
    1. 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

    相关文章

      网友评论

        本文标题:作用域链&&严格模式

        本文链接:https://www.haomeiwen.com/subject/xugftftx.html