es3.0
现在的浏览器基于es3.0使用的是es3.0+es5.0新增的方法
es3.0和es5.0产生冲突的部分在es5.0严格模式下采用es5.0否则采用es3.0
es5.0
es5.0严格模式
启动
在逻辑最顶端"use strict"
(字符串形式兼容老版本浏览器)
可以全局也可以局部(函数内)【一般使用局部的】
- 不能使用
arguments.callee
- 不能使用
with(){}
- 不能使用
this.caller
- 变量赋值前必须声明,es3.0未声明就辅助的变量为暗示全局变量
- 局部this必须被赋值,赋值什么就是什么(es3.0不能赋值为原始值,否则会自动变为包装类),预编译this不再指向window指向undefined
- 拒绝重复属性和参数(本质拒绝但不报错)
with(){}的作用是改变作用域链AO
通常用于简化调用操作
禁止原因是因为修改作用域链会大量消耗内核效率使得程序执行变慢
document.write('a');
with(document){
write('a');
}
var obj = {
name : "obj"
}
var name = 'window';
function test() {
var name = 'scope';
with(obj) {
console.log(name);
}
}
test();//输出结果为obj
eval()
能把传入的字符串当代码使用