消息提示

注册成功!

确定 取消
用户名: 密码: 注册
留言系统> 学习笔记>nodejs/reactjs等框架及工具
标题:ES6 的模块自动采用严格模式,不管你有没有在模块头部加上"use strict" 发帖时间:2017-06-21 16:25:52

乌托
严格模式
ES6 的模块自动采用严格模式,不管你有没有在模块头部加上"use strict";。

严格模式主要有以下限制。

变量必须声明后再使用
函数的参数不能有同名属性,否则报错
不能使用with语句
不能对只读属性赋值,否则报错
不能使用前缀0表示八进制数,否则报错
不能删除不可删除的属性,否则报错
不能删除变量delete prop,会报错,只能删除属性delete global[prop]
eval不会在它的外层作用域引入变量
eval和arguments不能被重新赋值
arguments不会自动反映函数参数的变化
不能使用arguments.callee
不能使用arguments.caller
禁止this指向全局对象
不能使用fn.caller和fn.arguments获取函数调用的堆栈
增加了保留字(比如protected、static和interface)
上面这些限制,模块都必须遵守。由于严格模式是 ES5 引入的,不属于 ES6,所以请参阅相关 ES5 书籍,本书不再详细介绍了。

其中,尤其需要注意this的限制。ES6 模块之中,顶层的this指向undefined,即不应该在顶层代码使用this。
1下一页  第1页,共1页
回复

标题: 回复:ES6 的模块自动采用严格模式,不管你有没有在模块头部加上"use strict"

内容:

发贴人: 游客