

2.在严格模式下,对变量名也是有限制.特别的,不能使用implements,interface,let,package,private等保留字作为变量名,用这些变量命名的话,都会导出语法错误
对象
在严格模式下 操作对象比在非严格模式下更容易导致错误,下面几种情形会导致语法错误
1.为只读属性赋值会抛出TypeError
2.对不可配置的属性使用delete 操作符会抛出TypeError
3.对不可扩展的对象添加属性会抛出TypeError
函数
在严格模式下,要求命名函数的参数必须是唯一的
// 重命名参数的
// 非严格模式:没有错误,只能访问第二个参数,如果要访问第一个参数,就必须通过arguments
// 严格模式语法错误
function sum(num,num){
//do something
}在严格模式下arguments对象的行为也有所不同.在严格模式下,修改命名参数的值也会反映到argument对象中,但是在严格模式下这两个值是完全独立的
function showValue(value){
value = 'foo'
console.log(value)
console.log(arguments[0]) // 非严格模式 : 'foo' 严格模式 :'hello'
}
showValu('hello')函数
在严格模式中,函数的参数必须唯一
// 重名的参数
// 非严格模式中,没有错误,只能访问第一个参数
// 严格模式 :抛出错误 Uncaught SyntaxError: Duplicate parameter name not allowed in this context
function sum(num,num){
'use strict'
// do something
}arguments对象
在非严格模式中,修改命名参数的值也会反应到arguments对象中,而严格模式坐下,这两个值是完全独立的
// 修改命名参数的值
// 非严格模式:修改会反应到arguments中
// 严格模式中不会反应到arguments中
function sum(num,num2){
'use strict'
num=3
console.log(arguments[0],num2)// 严格模式下eval()
eval函数最大的变化就是他在包含上下文中不在创建变量或者函数:
// 使用eval函数创建变量
// 非严格模式中:弹出框弹窗 20
// 严格模式中:调用alert(x)时报错
function doSomething(){
eval('var x=20')
alert(x)
}在严格模式中,可以在eval()中声明变量和函数,但这些边行或者函数只能在被求值的特殊作用域中有效,随后就将被销毁,下面这段代码执行就是没问题的
'use strict'
var result=eval('x=1,y=13;x+y')
alert(result)在这里,eval中声明了变量x和y,然后将他们加在一起,反悔了他们的和,于是result变量的值就是21,即x+y的结果,在调用alert时,尽管x和y已经不存在了,result变量的值还是有效的
抑制this
在非严格模式下使用函数的apply()或则call()方法时,null和undefined值会被转换为全局对象,而在严格模式下,函数的this值始终是指定的值,无论指定的是什么值:
// 访问属性
// 非严格模式:访问全局实行
// 严格模式:抛出错误,因为this的值是null
var color = "red";
function displayColor() {
alert(this.color);
}
displayColor(null);其他变化
在严格模式中with语句被抛弃掉了,在非严格模式中with语句能够改变解析标识符的路径,但在严格模式下,with语句被简化掉了,因此,在严格模式下使用with语句是导致语法错误
// with语句
// 非严格模式:允许
// 严格模式:抛出语法错误
with (location) {
console.log(href);
}相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读
js函数项目中常用方法总结
怎样使用原生js做出满天星效果
