电 话:0

手 机:0

联系人:刘先生

E_mail:2074917417@qq.com

地 址:成都市金牛区

您当前的位置是:主页 > 行业资讯 > news >

news

ECMAScript中eval()方法使用方法及注意事项

发布时间:2022/01/11 丨 文章来源:未知 丨 浏览次数:

我们介绍整个ECMAScript语言中最强大的一个方法:eval()。eval()方法就像是一个完整的ECMAScript解析器,它只接受一个参数,即要执行的ECMAScript(或JavaScript)字符串。看下面的例子:

eval("alert('专业做网站')");

这行代码的作用等价于下面这行代码:

alert("专业做网站");

当解析器发现代码中调用eval()方法时,它会将传人的参数当作实际的ECMAScript语句来解析,然后把执行结果插入到原位置。通过eval()执行的代码被认为是包含该次调用的执行环境的一部分,因此被执行的代码具有与该执行环境相同的作用域链。这意味着通过eval()执行的代码可以引用在包含环境中定义的变量,举个例子:

var msg="hello world";

eval("alert(msg)"); //"hello world"

可见,变量msg是在eval()调用的环境之外定义的,但其中调用的alert()仍然能够显示"helloworld"。这是因为上面第二行代码最终被替换成了一行真正的代码。同样地,我们也可以在eval()调用中定义一个函数,然后再在该调用的外部代码中引用这个函教:

eval("function sayHi() (alert('hi');)");

sayHi();

南昌网络公司技术人员提示,函数sayHi是在eval()内部定义的,但由于对eval()的调用最终会被替代换成定义函数的实际代码,因此可以在下一行调用sayHi().

能够解释代码字符的能力非常强大,但也非常危险.因此在使用eval()时必须极为谨慎,特别是在用它执行用户输入数据的情况下.否则,可能会有恶意用户输入威胁你的站点或应用程序安全代码(即所谓的代码注入).

本资料仅限南昌网站制作公司网络技术部内部人员交流使用,方便内部技术人员学习交流,请勿作其他用途.谢谢支持!

文章出自:南昌建网站公司-网络 http://www.huicuiwang.cn 如转载请注明出处


PS:所有作品版权归原创作者所有,与本站立场无关,如不慎侵犯了你的权益,请联系我们告知,我们将做删除处理!


网站首页 | app开发| 小程序开发| SEM竞价托管| 行业资讯

扫码关注我们