犀牛书随手记-01

eval()函数的理解
其使用过方法:接受一个字符串作为参数,并将这个字符串,转换为可执行的js代码执行;
值得注意的是,在这个函数中他调用变量的作用域是查找变量和定义新变量和函数的操作和局部作用域中的代码完全一样
例子:

    var a = 1;
    eval("console.log(a)");
    function fn(){
        var a = 3;
        eval("console.log(a)");
    }
    fn();
    // 1 3

值得注意的是,传递给eval的字符串必须在语义上面讲的通;而且eval的字符串执行的时候上下文环境和调用函数的环境是一样的。
例子

 function fn(){
        var a = 3;
        eval("return");
    }
    fn();
    // 报错误异常

在ECMAScript5 中 反对 使用 evalError 并且规范了eval的行为
例子

    var geval = eval;
    var a = 1;
    b = 2;
    c = 3;
    function fn1() {
        var a = 5;
        eval("a+=2");
        return a;
    }
    function fn2() {
        var b = 5;
        geval("b+=2");
        return b;
    }
    function fn3() {
        var c = 5;

        function fn() {
            var c = 6;
            geval("c+=2");
        }

        fn();
        return c;
    }
    console.log(fn1(), a);
    console.log(fn2(), b);
    console.log(fn3(), c);
    //  7 1 改变的是 fn1作用域内的局部变量
    //  5 4 改变的是 全局作用域下的变量
    //  5 5 改变的是 全局作用域下的

总结来说 直接调用eval的,它总是在调用它的上下文作用域内执行,间接调用的,则使用全局对象作为其上下文;

逗号 运算的

var a = (1,2,3,4);
// a 的结果为4

注意以上 均不在严格模式下

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值