javascript中的Function和eval

eval(String):可以计算字符串内容
example:

<script type="text/javascript">
    eval("x=10;y=20;document.write(x*y)");
    document.write(eval("2+2"));
    var x=10;
    document.write(eval(x+17));
</script>

输出为:200 4 27

    var jsstring="var un=1;console.log(un);";
    eval(jsstring);

    jsstring="var deux=2;console.log(deux);";
    new Function(jsstring)();

    jsstring="var trois=3;console.log(trois);";
    (function () {
        eval(jsstring);
    }());
    console.log(typeof un);
    console.log(typeof deux);
    console.log(typeof trois);

来看上面一段代码,在console可以看到输出结果为:
结果图
首先定义了全局变量 jsstring为字符串,eval执行了内容的计算,在控制台显示1,运行完成后un变为全局变量;Function中的代码将在局部函数运行,因此代码中deux不会成为全局变量,因此后面输出deux,trois的类型都是未定义。
无论哪里执行Function都仅仅能看到全局作用域,不改变局部变量,eval()则会访问和修改它外部作用域的变量。

<script type="text/javascript">
    (function(){
        var local=1;
        eval("local=3;console.log(local)");   //3
        console.log(local);//3
    }());
    (function(){
        var local=1;
        Function("console.log(typeof local);")();//undefined
        console.log(local); //1
    }());
</script>

有上述例子可以知道,Function不会把局部变量修改为全局变量

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值