eval()
JavaScript通过全局函数eval()可以解释运行由JavaScript源码组成的字符串并且产生一个值。
eval("25*4"); // == 100
eval()是一个原本是一个函数,但是已经被当成运算符来对待了。现代的JavaScript解释器进行了大量的代码分析和优化。eval()的问题在于,用于动态执行代码一般是不能分析。也就是,如果一个函数调用了eval(),解释器就无法对该函数做进一步优化。
eval()只有一个参数,如果该参数不是字符串,那就直接返回该参数;如果参数是字符串,则eval()会把字符串看成是JavaScript代码进行编译后再执行(如果编译错误的话,就抛出语法错误的异常)。
注:传给eval()的字符串必须在语法上讲的通的,而不是随意拷贝任意代码段。
eval()可以更改局部变量。直接调用eval()时,它总是在调用它的上下文作用域内执行。其他的间接调用则使用全局对象作为其上下文作用域,并且无法读、写、定义局部变量和函数。
严格模式下的eval()受到很多的限制,甚至是对标识符eval的使用也有限制。在严格模式下,eval执行的代码段可以查询或更改局部变量,但不能在局部作用域中定义新的变量或函数,并且将eval列为保留字。不能使用一个别名来覆盖eval()函数,而且变量名、函数名、函数参数以及异常捕获的参数也不能取名为"eval"。
所以在开发中尽量避免使用eval
typeof运算符
typeof是一元运算符,放在操作数前,返回一个表示操作数类型的一个字符串。
in运算符
in运算符希望它的左操作数是一个字符串或可以转换为字符串,希望它的右操作数是一个对象。如果右侧的对象拥有一个名为左操作数值的属性名,那么表达式返回true。可以简单理解为左操作数属于右操作数。
instanceof运算符
instanceof运算符希望左操作数是一个对象,右操作数标识对象的类。可以检测左操作数是否为右操作数的一个实例,这就涉及到了原型
delete运算符
用于删除对象的属性或者数组元素,和赋值、递增、递减运算符一样,但是delete也有副作用,delete只能用来删除操作而不能用来返回一个值。(删除属性或者删除数组的元素仅仅设置一个undefined的值,并没有改变数组的长度),当然并不是所有的属性都可删除,一些内置核心和客户端属性是不能删除的,用户通过var语句声明的变量不能删除。同样,通过function语句定义的函数和函数参数也不能删除。
在ES5中,如果delete的操作数是非法的(变量、函数、函数参数),则会抛出一个语法错误异常,只有操作数是一个属性可以访问的表达式时,才可以正常运行。
void运算符
放在操作数之前,操作数为任意类型。操作数会正常计算,但是忽略计算结果并且返回一个undefined。(不常用)
逗号运算符
逗号运算符是二元运算符,操作数为任意类型,先计算左操作数,再计算右操作数,最后返回右操作数的值。