JavaScript严格模式说明带示例
严格模式(use strict)
目的
- 消除JS中一些不合理、不严谨之处,减少一些怪异行为
- 消除代码中的一些不安全之处,保障代码运行安全
- 提高编译器效率,增加运行速度
- 为以后的JS新规范做铺垫
兼容性
FF、Chrome、IE10+、Safari、Opera
语法
"use strict";
老版本浏览器将以上源码当做字符串处理
使用范围
- 在整个脚本之前调用,整段脚本以严格模式执行
<script>
"use strict";
console.log('全局严格模式');
</script>
- 在函数内部之前调用,整个函数以严格模式执行
function fn() {
"use strict";
console.log('局部严格模式,只在函数内有效');
}
对行为和语法的控制
- 全局变量显示声明
- 正常模式下,变量没有声明,直接赋值,默认为全局变量;
- 严格模式禁止这种行为,全局变量必须用
var显式声明
//正常模式下
a = 1;
console.log(a);//1
//严格模式下
"use strict";
a = 1;
console.log(a);//报错
- 禁止使用
with
width语句在编译时无法确定属性归属于哪个对象 - 增加
eval作用域- 正常模式下,
eval中执行的作用于取决于它处于全局还是函数作用域内; - 严格模式下,
eval本身有独立的作用域
- 正常模式下,
//正常模式下
var a = 1;
console.log(eval('var a = 1;a'));//2
console.log(a);//2
//严格模式下
var a = 1;
console.log(eval('var a = 2;a'));//2
console.log(a);//1
this默认不指向全局对象window- 正常模式下,
this指向window; - 严格模式下,
this不再默认指向window
- 正常模式下,
//正常模式下
function fn() {
this.a = 1;
}
fn();
a;//1
//严格模式下
"use strict";
function fn() {
this.a = 1;
}
fn();
a;//报错
arguments和caller被禁用- 正常模式下,函数本身拥有默认属性
arguments指向传递的参数,caller指向函数引用; - 严格模式下,
arguments和caller被禁用,报错
- 正常模式下,函数本身拥有默认属性
- 禁止删除变量
- 正常模式下,
delete可以删除定义的变量; - 严格模式下,只有
configurable为true的对象属性才能被删除,var定义的变量不能被删除
- 正常模式下,
//正常模式下
var a = 1;
delete a;//a不会被删除,也不报错
a;//1
var obj = {
o1: 1,
o2: 2
};
delete obj.o1;//obj中o1属性被删除
obj.o1;//undefined;
//严格模式下
"use strict";
var a = 1;
delete a;//报错
a;//1
var obj = {
o1: 1,
o2: 2
};
delete obj.o1;
obj.o1;//undefined;
- 对只读属性赋值,会报错
- 正常模式下,对只读属性赋值时,不报错,只默认失败;
- 严格模式下,报错
- 对
getter方法赋值报错 - 对禁止扩展的对象添加新属性报错
- 删除不可删除的属性报错
- 对象不能有重名属性
- 正常模式下,对象中重名属性会被后面的重名属性覆盖;
- 严格模式下,语法错误,不会报错
- 函数不能有重名参数
- 正常模式下,函数下有重名参数时,正常输出参数,重名参数被后面的重名参数覆盖,使用
arguments输出时,可区分参数值; - 严格模式下,报错
- 正常模式下,函数下有重名参数时,正常输出参数,重名参数被后面的重名参数覆盖,使用
//正常模式下
function fn(a, a, b) {
console.log(a);
console.log(arguments[0]);
console.log(arguments[1]);
}
fn(1,2,3);//2 1 2
//严格模式下
"use strict";
function fn(a, a, b) {
console.log(a);
console.log(arguments[0]);
console.log(arguments[1]);
}
fn(1,2,3);//报错
- 禁用八进制
- 正常模式下,整数第一位如果是
0,表示八进制,可正常转换输出对应的十进制数; - 严格模式下,报错
- 正常模式下,整数第一位如果是
//正常模式下
console.log(012);//10
//严格模式下
'use strict';
console.log(012);//报错
- 不允许对
arguments赋值- 正常模式下,可对
arguments重新赋值; - 严格模式下,语法错误,参数值不会变
- 正常模式下,可对
- 不再对
arguments跟踪变化- 正常模式下,函数参数值发生变化时,
arguments也随之变化; - 严格模式下,不变
- 正常模式下,函数参数值发生变化时,
//正常模式下
function fn(a, b, c) {
arguments[1] = 4;
console.log(a, b, c);//1, 4, 3
console.log(arguments[1]);//4
}
fn(1, 2, 3);
//严格模式下
'use strict';
function fn(a, b, c) {
arguments[1] = 4;
console.log(a, b, c);//1, 2, 3
console.log(arguments[1]);//4
}
fn(1, 2, 3);
arguments.callee被禁用- 正常模式下,
arguments.callee指向函数引用; - 严格模式下,被禁用,报错
- 正常模式下,
//正常模式下
function fn(a) {
console.log(arguments.callee);
}
fn(1);//输出原函数体
//严格模式下
'use strict';
function fn(a) {
console.log(arguments.callee);
}
fn(1);//报错
- 函数必须被声明在顶层
- 正常模式下,函数可以被声明在
if或for代码块内; - 严格模式下,不允许,报错
- 正常模式下,函数可以被声明在
//正常模式下
if(true) {
function fn(a) {
console.log(a);
}
}
fn(1);//1
//严格模式下
'use strict';
if(true) {
function fn(a) {
console.log(a);
}
}
fn(1);//报错,函数不存在
- 新增保留字
- 严格模式下,新增关键字
implements、interface、let、package、private、protected、public、static、yield
- 严格模式下,新增关键字
JavaScript严格模式说明带示例的更多相关文章
- 面向对象的JavaScript --- 原型模式和基于原型继承的JavaScript对象系统
面向对象的JavaScript --- 原型模式和基于原型继承的JavaScript对象系统 原型模式和基于原型继承的JavaScript对象系统 在 Brendan Eich 为 JavaScrip ...
- JavaScript dotAll模式
JavaScript正则表达式中点(.)是一个特殊字符,它可以匹配除了一下条件的任意字符. 四个字节的UTF-16字符 换行符(\n) 回车符(\r) 行分隔符 段分隔符 为了使点(.)可以匹配任意字 ...
- javascript运行模式:并发模型 与Event Loop
看了阮一峰老师的JavaScript 运行机制详解:再谈Event Loop和[朴灵评注]的文章,查阅网上相关资料,把自己对javascript运行模式和EVENT loop的理解整理下,不一定对,日 ...
- Javascript原型模式总结梳理
在大多数面向对象语言中,对象总是由类中实例化而来,类和对象的关系就像模具跟模件一样.Javascript中没有类的概念,就算ES6中引入的class也不过是一种语法糖,本质上还是利用原型实现.在原型编 ...
- JavaScript严格模式详解
转载自阮一峰的博客 Javascript 严格模式详解 作者: 阮一峰 一.概述 除了正常运行模式,ECMAscript 5添加了第二种运行模式:"严格模式"(strict m ...
- (转)深入理解JavaScript 模块模式
深入理解JavaScript 模块模式 (原文)http://www.cnblogs.com/starweb/archive/2013/02/17/2914023.html 英文:http://www ...
- JavaScript严谨模式(Strict Mode)
下面的内容翻译自It’s time to start using JavaScript strict mode,作者Nicholas C.Zakas参与了YUI框架的开发,并撰写了多本前端技术书籍,在 ...
- 深入理解JavaScript 模块模式
http://www.adequatelygood.com/JavaScript-Module-Pattern-In-Depth.html 模块模式是JavaScript一种常用的编码模式.这是一般的 ...
- Javascript编程模式(JavaScript Programming Patterns)Part 1.(初级篇)
JavaScript 为网站添加状态,这些状态可能是校验或者更复杂的行为像拖拽终止功能或者是异步的请求webserver (aka Ajax). 在过去的那些年里, JavaScript librar ...
随机推荐
- js-权威指南学习笔记9
第九章 类和模块 1.在JS中,类的实现是基于其原型继承机制的,如果两个实例都从同一个原型对象上继承了属性,我们说它们是同一个实例. 2.常见的编程约定:定义构造函数既是定义类,并且类名首字母要大写. ...
- 布隆过滤器(BoomFilter)
1.原理: a.解决的问题: 判断一个元素是否在一个集合中 b.Hash表的特点: i.快速准确 ...
- Android相关修改教程
ICS: 自己动手实现接通震动功能 原生来电归属地修改教程
- 集群下Cookie共享,必须要设置machineKey
这个节允许你设置用于加密数据和创建数字签名的服务器特定的密钥.ASP.NET自动使用它来保护表单验证Cookie,你也可以将它用于受保护的视图状态数据.同时,这个密钥还用于验证进程外的会话状态提供程序 ...
- 从CK+库提取标记点信息
1.CK+动态表情库介绍 The Extended Cohn-Kanade Dataset(CK+) 下载地址 这个数据库是在 Cohn-Kanade Dataset 的基础上扩展来的,发布于2010 ...
- vs2015编译mysql c++ connector
目前MySQL Connector/C++的binary版本最高只支持VS2008,VS2015需要下载源码自行编译. 1.CMAKE 到官网下载最新的稳定版本 把bin目录添加到环境变量PATH中 ...
- 【动态规划】Gym - 101102A - Coins
Hasan and Bahosain want to buy a new video game, they want to share the expenses. Hasan has a set of ...
- Python科学计算之Pandas
Reference: http://mp.weixin.qq.com/s?src=3×tamp=1474979163&ver=1&signature=wnZn1UtW ...
- Apache/nginx转发设置-分布式部署
Apache转发设置1. Weblogic安装 Weblogic8和Weblogic10默认安装,选择完全安装即可,如果是Weblogic9则选择自定义安装,勾选WebService plugin 2 ...
- mysql 5.5中文乱码问题
一.登录MySQL查看用SHOW VARIABLES LIKE ‘character%’;下字符集,显示如下:+--------------------------+----------------- ...