java严格模式_严格模式

1、介绍严格模式

2、严格模式影响范围

变量: var、delete、变量关键字

对象: 只读属性、 对象字面量属性重复申明

函数:参数重名、arguments对象、申明

其他:this、eval、关键字...

严格模式

ECMAScript 5 引入严格模式('strict mode')概念。通过严格模式,在函数内部选择进行较为严格的全局或局部的错误条件检测,使用严格模式的好处是可以提早知道代码中的存在的错误,及时捕 获一些可能导致编程错误的ECMAScript行为。在开发中使用严格模式能帮助我们早发现错误。

设立"严格模式"的目的,主要有以下几个:错误检测、规范、效率、安全、面向未来

- 消除Javascript语法的一些不合理、不严谨之处,减少一些怪异行为;

- 消除代码运行的一些不安全之处,保证代码运行的安全;

- 提高编译器效率,增加运行速度;

- 为未来新版本的Javascript做好铺垫。

进入"严格模式"的编译指示(pragma),是下面这行语句:

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict";

这个语法从ECMAScript 3 开始支持。向后兼容不支持严格模式的浏览器,他们就当遇到了一个普通字符串,编译时忽略。

将"use strict"放在脚本文件的第一行,则整个脚本都将以"严格模式"运行。

如果这行语句不在第一行,则无效,整个脚本以"正常模式"运行。

如果不同模式的代码文件合并成一个文件,这一点需要特别注意。

(严格地说,只要前面不是产生实际运行结果的语句,"use strict"可以不在第一行,比如直接跟在一个空的分号后面。)

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict";

console.log("这是严格模式。");

将"use strict"放在函数体的第一行,则整个函数以"严格模式"运行。

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

function strict(){

"use strict";

return "这是严格模式。";

}

function notStrict() {

return "这是正常模式。";

}

建议只在特定的作用域中使用严格模式。放在全局作用域中(函数外部),页面的其他脚本也都处于严格模式下。因为上面的调用方法不利于文件合并,所以更好的做法是,下面的方法,将整个脚本文件放在一个立即执行的函数表达式

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

+function (){ "use strict";

}();

变量

非严格模式下,a = 1可以创建一个全局变量。

严格模式下,变量都必须先用var命令显示声明,然后再使用。 严格模式不允许意外创建的全局变量(示例),否则会报错(Uncaught ReferenceError: v is not defined )。

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict";

v= 1; //报错,v未声明

for(i = 0; i < 2; i++) { //报错,i未声明 ReferenceError

}

而且,严格模式不能对变量调用 delete操作符(示例),会导致错误(Uncaught SyntaxError: Delete of an unqualified identifier in strict mode. )。

非严格模式允许这样操作,但返回false 。

别用这些词做 变量名或 参数名 implements, interface, let, package, private, protected, public, static, yield。这些都是保留字,将来ECMAScript 版本中可能会用到他们。

严格模式下作为其保留关键字,使用这些标识符作为变量名会导致语法错误。

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

function package(protected){ //报错!

"use strict";var implements; //报错!

interface: //报错!

while (true){break interface; //报错!

}

functionprivate() { } //报错!

}

function fun(static) { 'use strict'; } //报错!

对象

为只读属性赋值报错(示例)

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict"

var testObj =Object.defineProperties({}, {

prop1: {

value:10,

writable:false //by default

},

prop2: {get: function () {

}

}

对象字面量同一个属性重复赋值(Uncaught SyntaxError: Unexpected identifier),非严格模式会取最后一个(示例)

Js代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict"

var person ={

name :"Tom"name :"Cat"}

另外两种情况:

为不可配置的属性使用delete操作符会抛出typeError

为不可扩展的对象添加属性会抛出TypeError

函数

严格模式下参数名不能重复(Uncaught SyntaxError: Strict mode function may not have duplicate parameter names)(示例)

非严格模式,函数内部实际访问的是第二个参数,要访问第一个参数必须通过arguments对象。

Java代码  e978c2aa07c098e1787a6aa2480292fe.png

"use strict"function sum(num, num) {}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值