《十四》JavaScript 中的严格模式

严格模式是JavaScript的一种限制性模式,旨在提高代码质量,防止意外的全局变量创建和错误的静默处理。在严格模式下,未声明的变量不会自动成为全局变量,尝试修改只读属性或使用相同参数名的函数会抛出错误,而且不允许使用`with`语句和特定的八进制语法。此外,`this`的绑定行为也有所不同,不会默认转换为对象。

JavaScript 不断向前发展并且没有带来任何兼容性的问题。新的特征被加入,旧的功能也没有改变,这么做有利于兼容旧代码;但是 JavaScript 创造者的任何错误或者不完善的决定也将永远被保留在 JS 这门语言中。

在 ES5 标准中,JS 提出了严格模式(Strict Mode)的概念。严格模式是一种具有限制性的 JS 模式,从而使代码隐式地脱离了懒散模式(Sloppy Mode)。

支持严格模式的浏览器在检测到代码中开启了严格模式后,会以严格的方式对代码进行检测和执行。

开启严格模式:

通过在文件或者函数的开头使用 "use strict" 来开启严格模式。可以对整个文件开启严格模式,也可以单独对某个函数开启严格模式。

ES6 中的 class 和 module 默认开启了严格模式。
打包后的代码一般都默认开启了严格模式。

严格模式对代码的限制:

  1. 严格模式下不允许 0 开头的八进制语法。

    0o 开头可以,0 开头不可以。

  2. 严格模式下不允许使用 with 操作符。
  3. 严格模式下 eval() 函数里创建的变量,外层引用不到。
    "use strict"
    eval(`var message = 'Hello'`)
    console.log(message) //  非严格模式下 eval 函数里创建的变量,外部也可以引用到;严格模式下报错:Uncaught ReferenceError: message is not defined
    
  4. 严格模式下不会创建意外的全局变量。
    "use strict"
    function fn() {
    	message = 'Hello' // 非严格模式下,不使用 var 声明的变量会被创建为全局变量;严格模式下,不使用 var 声明的变量不会被创建为全局变量
    }
    fn()
    console.log(message) // 非严格模式下能成功访问;严格模式下访问报错:Uncaught ReferenceError: message is not defined
    
  5. 严格模式下 this 绑定不会默认转成对象。

    全局的 this 不会被转成 window,而是 undefined;函数内部的 this 也不会被默认转成对象。

    function fn1() {
    	console.log(this)
    }
    fn1.apply('abc')
    
    function fn2() {
    	"use strict"
    	console.log(this)
    }
    fn2.apply('abc')
    
    请添加图片描述
  6. 严格模式下会将静默错误明确抛出。
    "use strict"
     var obj = {
    	message: 'Hello World'
     }
     Object.defineProperty(obj, 'message', {
    	writable: false // 配置为不可修改
     })
     obj.message = 'Hello JS'  // 非严格模式下修改不会抛出任何错误;严格模式下修改报错:Uncaught TypeError: Cannot assign to read only property 'message' of object '#<Object>'
    
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值