1、概述

  除了正常模式,ECMAscript 5添加了第二种运行模式:“严格模式”(strict mode)。顾名思义,这种模式使得javascript在更严格的条件下运行。

2、为什么要用严格模式?

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

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

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

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

  “严格模式”体现了javascript更合理、更安全、更严谨的发展方向,包括IE10在内的主流浏览器都已经支持它,许多大项目已经开始全面拥抱它。

  另一方面,一些在“正常模式”下可以运行的代码,在“严格模式”下,可能将不能运行。

3、进入标志

  “use strict”;

4、如何调用

  - 针对单个脚本

    <script>

      "use strict";

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

    </script>

  - 针对单个函数

    function strict(){

      "use strict";

      return "这是严格模式";

    }

    function noStrict(){

      return "这是正常模式";  

    }

5、语法和行为的改变

  - 全局变量显式声明

    在正常模式下,如果一个变量没有声明就赋值,默认为全局变量;在严格模式下禁止这样做,全局变量必须显式声明。

    “use strict”;

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

    for(i=0;i<2;i++){

      /*报错,i未声明*/

    }

  - 禁止this关键字指向全局对象

    function fn(){

      return !this;  /*返回false,因为“this”指向全局对象,“!this”就是false;*/

    }

    function fn(){

      "use strict";

      return !this;  /*返回true,因为严格模式下,this的值为undefined,所以“!this”为true;*/

    }

    因此,使用构造函数时,如果忘了加new,this不再指向全局对象,而是报错。

    function fn(){

      "use strict";

      this.num=1;

    }

    fn();  /*报错,this未定义*/

  - 禁止删除变量

    严格模式下,无法删除变量。只有configurable设置为true的对象属性,才能被删除。

    “use strict”;

    var x;

    delete x;  /*语法错误*/

    var o=Object.create(null,{'x':{

      value:1;

      configurable:true;

    }})

    delete o.x;  /*删除成功*/

  - 对象不能有重名的属性

    正常模式下,如果对象有多个重名属性,最后赋值的那个属性会覆盖前面的值。在严格模式下,这属于语法错误。

    “use strict”;

    var fn={

      a:1,

      a:2  /*语法错误*/

    }

  - 函数不能有重名的参数

    正常模式下,如果函数有多个重名的参数,可以用arguments[i]读取,严格模式下,这属于语法错误。

    “use strict”;

    function fn(a,a,b){  /*语法错误*/

      return ..

    }

转载于:https://www.cnblogs.com/meway/p/5824714.html

关于JS中的严格模式相关推荐

  1. JS中的严格模式(Strict Mode)

    什么是严格模式? 严格模式是ECMAScript5的新特性,它是采用具有限制性JavaScript变体的一种方式,从而使代码隐式地脱离"马虎模式/稀松模式/懒散模式"(sloppy ...

  2. 关于js中namespace命名空间模式

    命名空间有助于减少程序中所需要的全局变量的数量,并且同时有助于避免命名冲突或过长的名字前缀. 关于命名空间的例子: /** * 创建全局对象MYAPP * @module MYAPP * @title ...

  3. JS中使用工厂模式创建对象

    <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8" ...

  4. js中的设计模式之组合模式

    Js中的组合模式 定义 是一种将对象组合成树状结构的层次结构模式,用来表示 整体-部分 的关系,使用用户对单个对象和组合对象具有一致的访问性. 详细描述 组合模式是一个树形结构,里面的数据可以是单个对 ...

  5. JS中的THIS处理及正则表达式 — 1、callapplyjson

    1.大纲 面向对象深入了解 函数的三种角色:函数也是对象 Function Function.prototype:call/apply/bind 面试题讲解 ... call && a ...

  6. js架构设计模式——由项目浅谈JS中MVVM模式

    1.    背景 最近项目原因使用了durandal.js和knockout.js,颇有受益.决定写一个比较浅显的总结. 之前一直在用SpringMVC框架写后台,前台是用JSP+JS+标签库,算是很 ...

  7. 由项目浅谈JS中MVVM模式

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.    背景 最近项目原因使用了durandal.js和knock ...

  8. js中的4种函数调用模式:函数调用、方法调用、构造器调用、间接调用

    全栈工程师开发手册 (作者:栾鹏) js系列教程4-函数.函数参数教程全解 js中的4种函数调用模式 javascript一共有4种调用模式:函数调用模式.方法调用模式.构造器调用模式和间接调用模式. ...

  9. js中的设计模式之中介者模式

    Js中的中介者模式 定义 定义一个中介者对象来封装一系列对象的交互,把一批原来交互关系复杂的对象转换成一组松散耦合的对象,使他们变得易于维护和修改. 详细描述 在我们开发中经常会将对象拆分为更小的颗粒 ...

  10. JS笔记 | JS中的strict model(严格模式)

    仅做笔记分享,如有错误请高手指出 ECMAscript5中引入了strict model.严格模式下的JS程序需要比非严格模式下的程序更加规范.严格模式对语法做了比较严格的要求, 变量上的不同 mes ...

最新文章

  1. python学习干货教程(10):列表
  2. 【struts2+hibernate+spring项目实战】Spring计时器任务 Spring整合JavaMail(邮件发送)(ssh)
  3. 记录java应用部署到k8s中
  4. 千兆网线8根线定义图_家中的网线断裂/不够长,如何接线才最合适?
  5. OpenSessionInViewFilter 的配置
  6. exchange功能在线测试
  7. 计算机控制开关,开关电源的计算机控制系统
  8. Chrome FeHelper 插件下载地址
  9. windows用户密码破解
  10. [AngularJS面面观] 20. 依赖注入 --- instance注入器以及provider注入器
  11. 微信公众号开发引导用户关注公众号
  12. 基于信息熵的新词发现算法
  13. 客户问我,他都已经提供了那么多硬盘,你们之前也说可以存满90天,为什么监控录像还是没有90天?
  14. Cocos Creator入门实战:桌球小游戏
  15. 1. Win 10 :在此处打开命令窗口
  16. Windows文件夹用“命令行窗口”打开
  17. C++编程的精品文章整理
  18. endnote批量导入.enw格式参考文献
  19. 员工上班时间内高效率逛淘宝,企业如何解决?
  20. PDF文件怎么设置加密

热门文章

  1. 枫之谷m平板玩服务器维护,枫之谷 M无法连接服务器是什么原因
  2. exif viewer java,1earn/XSS挑战-WalkThrough.md at master · dizhaung/1earn · GitHub
  3. Web开发入门型服务器使用心得
  4. 《实施Cisco统一通信管理器(CIPT1)》一2.7 总结
  5. 关于web中的自适应布局
  6. java开发_eclipse导出为war文件,热部署到tomcat运行总结[转]
  7. Adb命令笔记 --菜鸟的笔记
  8. EditText控件(圆角处理)
  9. struts2.2跟jstl怎么整合
  10. ORM 革命 —— 复兴 | ORM Revolution -- Revived