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 ...
随机推荐
- 19、手把手教你Extjs5(十九)模块Grid的其他功能的设想
经过对自定义模块和Grid的设计和编码,现在已经能对一个有配置信息的模块来生成界面并进行一些简单的CURD操作.由于这是一个全解释性的前台的架构,因此你想到的任何新主意都可以放到所有的模块中. 比如对 ...
- Memcached源码分析之从SET命令开始说起
作者:Calix 如果直接把memcached的源码从main函数开始说,恐怕会有点头大,所以这里以一句经典的“SET”命令简单地开个头,算是回忆一下memcached的作用,后面的结构篇中关于命令解 ...
- 只要单片机具有真正唯一ID,就可以让加密坚不可摧(转)
源:只要单片机具有真正唯一ID,就可以让加密坚不可摧 http://www.amobbs.com/thread-5518980-1-1.html 第一环:ID-->F1(ID) -----> ...
- RoundedImageView使用吐槽心得(RoundedImageView与Glide加载图片,第一次加载无法圆角问题)
最近使用的时候发现一个问题, RoundedImageView与Glide搭配使用的时候,第一次加载图片(内存中没有),后图片无法圆角,后来尝试各种改,最后想到了一个办法,就是让Glide加载图片的 ...
- EasyUI--datebox设置默认时间
1. html代码: <input id="txtBeginTime" class="easyui-datebox" data-options=" ...
- java学习(二)--excel导出
public static String writeFile(String fileName, String[][] content) { WritableWorkbook wwb = null; S ...
- IOS开发-UI学习-UIWebView,简单浏览器的制作
制作一个简单的浏览器,包含网址输入框,Search按钮,前进.回退按钮,UIWebView就这几个简单的控件. UITextField:用来输入网址: UIbuttom:实现前进,后退,搜索等功能: ...
- IO文件
在Windows下的路径分隔符和Linux下的路径分隔符是不一样的,当直接使用绝对路径时,跨平台会暴出“No such file or diretory”的异常. Separator: 比如说要在te ...
- iOS 专题 之 界面开发 之 控件
iOS 之 UIViewController iOS 之 Navagation Button iOS 之 UIButton iOS 之 UITextField iOS 之 UIStackView iO ...
- spark在集群上运行
1.spark在集群上运行应用的详细过程 (1)用户通过spark-submit脚本提交应用 (2)spark-submit脚本启动驱动器程序,调用用户定义的main()方法 (3)驱动器程序与集群管 ...