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 ...
随机推荐
- php 中文切割字符串长度
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true) { if(function_ex ...
- UVa 10179 - Irreducable Basic Fractions
题目大意:给一个正整数n,求出在[1, n]区间内和n互质的正整数的个数.Euler's Totient(欧拉函数)的直接应用. #include <cstdio> #include &l ...
- onethink的插件扩展
2014年7月25日 07:22:35 编写一个文章可以同步到微博的插件 思路:首先要进行微博的绑定,获得令牌.然后调用微博的api即可. 2014年7月25日 08:40:27 服务器与本地有区别. ...
- UVa 594 - One Little, Two Little, Three Little Endians
题目大意:大小端模式的转换.所谓的小端模式,是指数据的高位保存在内存的高地址中,而数据的低位保存在内存的低地址中.与此相对,所谓的大端模式,是指数据的高位,保存在内存的低地址中,而数据的低位,保存在内 ...
- python callable 函数
callable(object) 中文说明:检查对象object是否可调用.如果返回True,object仍然可能调用失败:但如果返回False,调用对象ojbect绝对不会成功. 注意:类是可调用的 ...
- JavaScript易错点转载
前言 本文是我学习JavaScript过程中收集与整理的一些易错知识点,将分别从变量作用域,类型比较,this指向,函数参数,闭包问题及对象拷贝与赋值这6个方面进行由浅入深的介绍和讲解,其中也涉及了一 ...
- dev使用3
http://www.cnblogs.com/yuerdongni/archive/2012/09/08/2676748.html http://www.cnblogs.com/yuerdongni/ ...
- 判断activity是否显示在界面上
boolean result = false; ActivityManager am = (ActivityManager) context .getSystemService(Context.ACT ...
- 安卓自定义类似TabHost的导航栏
有时候为了项目需要我们要自定义一些导航控件,类似下面这样. 下面给大家讲讲我是怎么实现的, 1.素材准备(这个都是美工的事情) 2.①资源文件共有五个 如下: activity_main_first. ...
- 怎样看paper 最有效率
thinking more after reading. Don't just read the papers.in addition, at begining, you'd better focus ...