eval()函数用来执行由字符串所构成的语句
语法
eval(string)
参数:
string
: 这个字符串用来代表Javascript的表达式、语句或者一系列的语句,表达式中可以包含变量和已经存在对象的属性
返回值:
eval()函数的返回值就是string的执行返回结果,如何理解string的执行结果,下面给几个例子解释一下:
1 + 2
上面这段表达式的执行结果毋庸置疑会是3, 所以如果你调用eval('1 + 2')
则返回值会是3
alert('hi, javascript is awesome!')
alert函数的调用完并没有返回结果,javascript对于没有返回值的表达式或语句,默认的返回值是undefined
,所以eval("alert('hi, javascript is awesome!')")
的返回值是undefined
用途
eval()函数的用途是用来执行动态生成javascript的应用场景
注意事项
- eval()函数执行的时候给予调用者的很大的权限,在应用的时候需要考虑恶意脚本注入客户端执行,用来盗取用户相关信息。
- 不易debug;
- eval()的执行速度相当的慢,主要涉及到解析器的解析