JS严格模式

JavaScript的严格模式是一种限制性更强的模式,它可以防止一些常见的编程错误。开启严格模式在脚本或函数顶部添加usestrict。严格模式禁止意外创建全局变量,使无效的赋值操作抛出异常,要求函数参数名唯一,不允许八进制数字,并且限制this的指向等。在严格模式下,arguments对象与命名参数的关联也有所不同。
摘要由CSDN通过智能技术生成

JS严格模式

严格模式很好理解,是一种具有限制性的JavaScript模式,从而使代码隐式的脱离了 ”懒散(sloppy)模式“;

如何开启严格模式

在js文件的第一行 "use strict"

(特定函数严格模式)在函数的作用域内部单独开启严格模式,仅仅对这个函数的内部生效
function fn() {
  "use strict";
}

严格模式限制了什么?

1.禁止意外创建全局变量
/ 1. 禁止意外创建全局变量,
message = "Hello World"
// 在严格模式下这种未定义就赋值的写法是不被允许的
console.log(message)
function foo () {
  age = 20
  // 在严格模式下这种未定义就赋值的写法是不被允许的,而在非严格模式下会创建一个age全局变量
}
2.严格模式会使引起静默失败 (silently fail,注:不报错也没有任何效果) 的赋值操作抛出异常
// 给不可写属性赋值  在默认模式下不会报错但是在严格模式下就会报错
var obj1 = {};
Object.defineProperty(obj1, "x", { value: 42, writable: false });
obj1.x = 9; // 抛出 TypeError 错误

// 给只读属性赋值
var obj2 = { get x() { return 17; } };
obj2.x = 5; // 抛出 TypeError 错误

// 给不可扩展对象的新属性赋值
var fixed = {};
Object.preventExtensions(fixed);
fixed.newProp = "ohai"; // 抛出 TypeError 错误
3.在严格模式下,试图删除不可删除的属性时会抛出异常 (之前这种操作不会产生任何效果)
"use strict";
delete Object.prototype; // 抛出 TypeError 错误
4.,严格模式要求函数的参数名唯一。在正常模式下,最后一个重名参数名会掩盖之前的重名参数
function sum(a, a, c) { // !!! 语法错误
  "use strict";
  return a + a + c; // 代码运行到这里会出错
}
5.严格模式禁止八进制数字语法
6.禁止设置基本数据类型的属性
"use strict";

false.true = ""; // TypeError
(14).sailing = "home"; // TypeError
"with".you = "far away"; // TypeError

7.禁止this关键字指向全局对象
'use strict'
    function fn() {
      console.log(this) undefined
      this.name = 'jack' 报错
    }
    fn()
8.使用字面量时,属性名必须唯一
9.函数体中的arguments
非严格模式下修改命名参数也会反映到arguments对象上
严格模式下这两个值是独立的
function fn(value) {
      value = 'fofo'
      console.log(arguments[0]) //严格模式下输出 hi    非严格模式下输出fofo
    }
    fn('hi')
10.if语句中声明函数
严格模式下导致错误
非严格模式下将函数提升到if语句外,能够在浏览器运行
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值