程序员社区

javascript严格模式详解

除了正常模式下,es5中新增了严格模式,接下来将详细针对严格模式分析。

一、使用严格模式的好处

1、消除javascript中不合理,不严谨的地方,减少怪异行为。
2、消除javascript代码的不安全之处,保证代码的安全运行。
3、提高编译效率,增强运行速度。
4、为未来新版本的javascript做铺垫。

二、使用严格模式的标志

使用严格模式的标志是增添一个字符串,"use strick",对于一些低版本的浏览器,会将其当做一个字符串来解析。

三、如何调用

严格模式的调用主要分为两种,一种是整个脚本调用,另一种是函数内部调用。
1、整个脚本调用
<script>
	"use strict"
	......	
</script>
2、在函数内部调用
function say(){
	"use strict"
	......
}
第一种调用方式不利于脚本的合并,所以一般我们将这个脚本的代码放到一个立即执行函数中,然后在函数中使用严格模式。
;(function(){
	"use strict"
	......
})()

四、具体的语法改变

1、在非严格模式下,定义变量可以不使用var(let),这样变量就会放到window对象上,但是在严格模式下,不使用var(let)就会报错。

function func() {
  "use strict"
  v = 10         //报错
  console.log(v)
}
func()
2、静态绑定
因为js语言存在一个特点就是属性归属于那个对象可以是动态的,就是在语言编译阶
段可以不确定属性属于哪个对象,在执行阶段确定也是可以的。但是这样做导致编译
效率低,容易出现意外,不易阅读。所以在严格模式下要求在编译阶段属性确定属于
那个对象。
1、在with语句中,例如下面的代码,在编译时就无法确定属性的归属。

var v = 10
with(o){
	v  = 20
}

所以在严格模式下,就会报错。

2、eval()语句在严格模式下,独自处于一个作用域中。因为在普通模式下,如果
eval函数处于全局作用域,则在其中定义的变量就在全局作用域中,如果处于局部作
用域中,则在eval()函数中定义的变量就在局部作用域中。

'use strict'
eval("var x = 10; console.log(x)")
console.log(x)  //ReferenceError: x is not defined

3、增强安全措施
1、在严格模式下,函数中的this不再指向window对象.值为undefined

function func() {
  "use strict"
  console.log(!this)    //true
}
func()
如果要是构造函数中,使用this,但是在实例化时,并没有使用new关键字,则报错。
function Person() {
  "use strict"
  this.name = "DMC"  
}
Person()  //报错

2、禁止在函数中遍历调用栈。
function f1() {
	"use strict"
	f1.caller;     //报错
	f1.arguments;  //报错
}
4、在严格模式下禁止删除变量,只能删除configurable为true的属性
"use strict"
var x
delete x
//语法错误 SyntaxError: Delete of an unqualified identifier in strict mode.
5、显示报错
1、在正常模式下,如果对于一个不能重写的属性进行重写,不能更改,也不会报错,但是在严格模式下,会报错。

"use strict"
var o = {}
Object.defineProperty(o, "v", {value:"2", writable:false})
console.log(o.v)   //2
o.v = 3           //报错
console.log(o.v) 

2、在严格模式下,如果对于一个对象的getter属性进行赋值,会报错。

"use strict"
var o = {
  get v() {
    return 1
  }
}
o.v = 2  //报错
  
3、在严格模式下,对禁止扩展属性进行新增属性时,会报错。
"use strict"
var o = {}
Object.preventExtensions(o)
o.v = 2  //报错

4、在严格模式下,删除一个不可删除的属性会报错。
"use strict"
delete Object.prototype
6、在严格模式下,函数不能有重名属性的错误。
"use strict"
function add(a, a, b) {
   //报错
}
add()
7、严格模式下,禁止使用0作为八进制语法,可以使用0o
"use strict"
console.log(011)  //报错
81、严格模式下,不允许对arguments进行赋值。
 "use strict";

  arguments++; // 语法错误

  var obj = { set p(arguments) { } }; // 语法错误

  try { } catch (arguments) { } // 语法错误

  function arguments() { } // 语法错误

  var f = new Function("arguments", "'use strict'; return 17;"); // 语法错误


2、严格模式下,arguments不再追踪参数变化。
"use strict"
function func(a) {
  a = 2
  console.log(a, arguments[0])   //2,1
}
func(1)

3、禁止使用arguments,callee
这意味着,你无法在匿名函数内部调用自身了
  "use strict";

  var f = function() { return arguments.callee; };

  f(); // 报错

9、函数必须声明在顶层
不允许在非函数代码块中声明函数
  "use strict";

  if (true) {

    function f() { } // 语法错误

  }

  for (var i = 0; i < 5; i++) {

    function f2() { } // 语法错误

  }
10、使用保留字作为变量名会报错。

赞(0) 打赏
未经允许不得转载:IDEA激活码 » javascript严格模式详解

一个分享Java & Python知识的社区