1.LHS查询的时候
严格模式下,当引擎进行LHS查询时,若在全局作用域下还未找到目标变量,则在全局作用域下创建一个具有该名称的变量;
而在非严格模式下,引擎会抛出ReferenceError异常。
2.欺骗词法作用域时 的eval(…)
eval(…)接受一个字符串参数,我理解为是在运行期时,这个参数被视为书写时就存在在程序这个位置的代码,就是用程序生成代码并执行,从而欺骗(即修改)了词法作用域。
但是在严格模式下,这个参数中的声明无法修改所在的作用域了。
eval(…)小扩展:
它会执行括号中的内容,即使里面有可执行的代码,仍旧会执行,所以,当里面有第三方恶意代码时,使用eval很危险。
在图片的第一个例子中,先输出123,后输出洪七。