1. 程式人生 > >js的嚴格模式

js的嚴格模式

AR ack 其他 要求 nts 讀屬性 什麽 嚴格模式 ram

什麽是嚴格模式?

使JS編碼更加規範化的模式,消除Javascript語法的一些不合理、不嚴謹之處,減少一些怪異行為

怎麽使用?

直接添加下面的這句字符串就可以了,這種語法可以向後兼容,如果是不支持嚴格模式的javascript引擎,就會直接當成是一個未賦值的字符串字面量,會直接忽略,支持的引擎就會開啟嚴格模式

‘use strict‘

說明:

1.在全局作用域使用的話,那整個js腳本就會開啟這種模式

2.如果是只在函數內部使用的話,那麽就只是該函數內部開啟而已

function doSomething(){
  ‘use strict‘  
  // 其他代碼  
}

變量

1. 在嚴格模式中什麽時候創建變量以及怎麽創建變量都是有限制的.首先,不允許意外創建全局變量.在非嚴格模式下是可以像下面這樣創建全局變量,但是嚴格模式中是不可以的

// 未聲明變量
// 非嚴格模式:創建全局變量
// 嚴格模式 :拋出referenceEror錯誤

2.在嚴格模式下,對變量名也是有限制.特別的,不能使用implements,interface,let,package,private等保留字作為變量名,用這些變量命名的話,都會導出語法錯誤

對象

在嚴格模式下 操作對象比在非嚴格模式下更容易導致錯誤,下面幾種情形會導致語法錯誤

1.為只讀屬性賦值會拋出TypeError

2.對不可配置的屬性使用delete 操作符會拋出TypeError

3.對不可擴展的對象添加屬性會拋出TypeError

函數

在嚴格模式下,要求命名函數的參數必須是唯一的

//
重命名參數的 // 非嚴格模式:沒有錯誤,只能訪問第二個參數,如果要訪問第一個參數,就必須通過arguments // 嚴格模式語法錯誤 function sum(num,num){ //do something }

在嚴格模式下arguments對象的行為也有所不同.在嚴格模式下,修改命名參數的值也會反映到argument對象中,但是在嚴格模式下這兩個值是完全獨立的

function  showValue(value){
  value = ‘foo‘
  console.log(value)
  console.log(arguments[0]) // 非嚴格模式 : ‘foo‘  嚴格模式 :‘hello‘
} showValu(‘hello‘)

函數

在嚴格模式中,函數的參數必須唯一

// 重名的參數
// 非嚴格模式中,沒有錯誤,只能訪問第一個參數
// 嚴格模式 :拋出錯誤 Uncaught SyntaxError: Duplicate parameter name not allowed in this context
function
sum(num,num){ ‘use strict‘ // do something }

arguments對象

在非嚴格模式中,修改命名參數的值也會反應到arguments對象中,而嚴格模式坐下,這兩個值是完全獨立的

// 修改命名參數的值
// 非嚴格模式:修改會反應到arguments中
// 嚴格模式中不會反應到arguments中

function sum(num,num2){
    ‘use strict‘
num=3
   console.log(arguments[0],num2)// 嚴格模式下輸出為1,2 非嚴格模式下輸出為3,2
}
sum(1,2)

js的嚴格模式