Javascript 严格模式的一些理解

平常我们在ECMAscript5中可以声明以下的变量

num = 5;

console.log(num);//输出的是变量5

而为了Javascript更合理、更安全、更严谨的方向发展,添加了一种新的模式进来 - “严格模式”

严格模式的主要目的

1、消除javascript的一些不严谨、不合理之处,减少一些怪异的错误;

2、消除代码的一些不安全,保证代码的安全

3、提高编译效率,增加运行速度

4、为未来新版本的javascript做好铺垫

支持严格模式下的浏览器:Internet Explorer 10 +、 Firefox 4+ Chrome 13+、 Safari 5.1+、 Opera 12+

进入严格模式使用 “use strict”语句

老版本的浏览器会默认当成一串字符串执行

如果要以严格模式进行代码编译,需要把“use strict”写在脚本内的第一行

例1:

  <script>

    “use srtrict”; //这是一个严格模式的执行代码,写在脚本内的第一行

     var num = 1;

     console.log(num);

  </script>

  

  <script>  

     var num = 1;  //这是正常模式

     console.log(num);

  </script>

严格模式也可以针对单个函数进行执行

例2:<script>

    function strict (){  

    “use strict”;

     return ‘这是严格模式’;

    }

     

    function notStrict (){  

     return ‘这是正常模式’;

    }

   </script>

可以将严格模式放在立即执行函数中

例3:  (function(){

    “use strict”;

    })();

严格模式对Javascript的语法和行为,都做了一些改变

在正常模式中,如果一个变量没有生命便赋值,默认是全局变量 例如:a = 1; 严格模式中严禁这种写法,全局变量必须显示生命,添加var

例4: <script>

     “use strict”;

      i = 1;

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

     </script>

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

在普通函数下,this的指向是全局对象window,在严格模式下,this的值为undefined,所以在构造函数下

function f(){

    "use strict";

    this.a = 1;

  };

  f();// 报错,this未定义

严格模式下无法删除变量,只有将configurable设置为true
“use strict”;

var x;

delete x //报错,语法错误

var o = Object.create(null, {'x': {
      value: 1,
      configurable: true
  }});

  delete o.x; // 删除成功

 

posted on 2020-11-26 14:44  sbird  阅读(91)  评论(0编辑  收藏  举报

导航