• JavaScript 严格模式(use strict)


    use ‘strict’: "严格模式"是一种在JavaScript代码运行时自动实行更严格解析和错误处理的方法。这种模式使得Javascript在更严格的条件下运行。

    最好只在函数内使用严格模式。例如:

    function doSomething() { 
      “use strict”; 
      // 严格模式下运行 
    }

    function doSomethingElse() { 
      // 非严格模式下运行 

    如果你想严格模式应用于多个函数:

    (function() { 

    1. "use strict";
    2.  function doSomething() {
      1.    // this runs in strict mode
    3.  }
    4.  function doSomethingElse() {
      1.    // so does this
    5.  }

    }()); 

    设立"严格模式"的优点:

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

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

    3. 提高编译器效率,增加运行速度;

    4. 为未来新版本的Javascript做好铺垫。

    注:经过测试 IE6,7,8,9 均不支持严格模式。

    缺点:

    现在网站的 JS 都会进行压缩,一些文件用了严格模式,而另一些没有。这时这些本来是严格模式的文件,被 merge 后,这个串就到了文件的中间,不仅没有指示严格模式,反而在压缩后浪费了字节。

    事例:

    1.  变量必须先声明,再使用
    2.  function test(){
      1.    "use strict";
      2.    foo = 'bar'; // Error
    3.  }
    4.  不能对变量执行delete操作
    5.  var foo = "test";
    6.  function test(){}
    7.  delete foo; // Error
    8.  delete test; // Error
    9.  function test2(arg) {
      1.    delete arg; // Error
    10.  }
    11.  对象的属性名不能重复
    12.  { foo: true, foo: false } // Error
    13.  禁用eval()
    14.  函数的arguments参数
    15.  setTimeout(function later(){
      1.    // do stuff...
      2.    setTimeout( later, 1000 );
    16.  }, 1000 );
    17.  禁用with(){}
    18.  不能修改arguments
    19.  不能在函数内定义arguments变量
    20.  不能使用arugment.caller和argument.callee。因此如果你要引用匿名函数,需要对匿名函数命名。 

    1.使调试更加容易。那些被忽略或默默失败了的代码错误,会产生错误或抛出异常,因此尽早提醒你代码中的问题,你才能更快地指引到它们的源代码。

    2.变量在赋值之前必须声明,防止意外的全局变量。如果没有严格模式,将值分配给一个未声明的变量会自动创建该名称的全局变量。这是JavaScript中最常见的错误之一。在严格模式下,这样做的话会抛出错误。

    3.取消this值的强制转换。如果没有严格模式,引用null或未定义的值到 this 值会自动强制到全局变量。在严格模式下,引用 null或未定义的 this 值会抛出错误。严格模式下,this不会指向window 

    4.不允许重复的属性名称或参数值。当检测到对象中重复命名的属性,例如:

          var object = {foo: "bar", foo: "baz"};

          或检测到函数中重复命名的参数时,例如:

          function foo(val1, val2, val1){})

          严格模式会抛出错误,因此捕捉几乎可以肯定是代码中的bug可以避免浪费大量的跟踪时间。 

    5.使 eval() 更安全。在严格模式和非严格模式下, eval() 的行为方式有所不同。最显而易见的是,在严格模式下,变量和声明在 eval() 语句内部的函数不会在包含范围内创建(它们会在非严格模式下的包含范围中被创建,这也是一个常见的问题源)。

    eval()没有被移除,但它在严格模式下发生了一些变化。最大的改变是:在eval()语句中声明的变量以及函数不会在包含域中创建。例如:

    (function() {

    1.  eval("var x = 10;");
    2.  // 非严格模式下,x为10
    3.  // 严格模式下,x没有声明,抛出一个错误
    4.  alert(x);

    })(); 
    任意由eval()创建的变量或函数仍呆在eval()里。然而,你可以通过从eval()中返回一个值的方式实现值的传递:

    (function() {

    1.  var result = eval("var x = 10, y = 20; x + y");
    2.  // 严格模式与非严格模式下都能正常工作(得到30)
    3.  alert(result);

    }()); 

    6.在 delete 使用无效时抛出错误。 delete 操作符(用于从对象中删除属性)不能用在对象不可配置的属性上。当试图删除一个不可配置的属性时,非严格代码将默默地失败,而严格模式将在这样的情况下抛出异常。

    7.严格模式去除了with语句 

    8.不能修改arguments ,不能在函数内定义arguments变量  ,不能使用arugment.caller和argument.callee。因此如果你要引用匿名函数,需要对匿名函数命名。  

  • 相关阅读:
    python3+request接口自动化框架
    类型转换函数
    操作符重载(三)
    操作符重载(二)
    操作符重载(一)
    时间获取函数
    文件和目录
    Linux五种IO模型
    类中的函数重载
    系统调用IO和标准IO
  • 原文地址:https://www.cnblogs.com/loving0606/p/14085917.html
Copyright © 2020-2023  润新知