首頁 >web前端 >js教程 >怎麼使用JS嚴格模式

怎麼使用JS嚴格模式

php中世界最好的语言
php中世界最好的语言原創
2018-04-12 16:19:302106瀏覽

這次帶給大家怎麼使用JS嚴格模式,使用JS嚴格模式的注意事項有哪些,下面就是實戰案例,一起來看一下。

所謂嚴格模式其實就是一個不會賦值給任何變數的字串 「use strict」

如果在全域作用域下 給予這個提示,那麼整個腳本將會採用嚴格模式。也可以只在函數中開啟嚴格模式

# 1.嚴格模式下沒有全域變數

a="test"

# 嚴格模式下會報錯,非嚴格模式下正常

2.刪除變數

# var 有三種宣告的情形

  • var 宣告的全域變數

  • var 宣告的局部變數

  • #eval()中宣告的全域變數

第一種和第二種情況是無法用 delete刪掉的。

首先第一種情況宣告的全域物件雖然是windows的屬性,但這個屬性的configurable=false 因此是無法刪除的

第二種情況 局部變數更不行了,連依附的物件是誰都不知道,怎麼刪除

第三種情況eval()稍後會說到。

回歸正題。也就是說非嚴格模式下,可以刪除變量,但會失敗回傳false.

# 嚴格模式下刪除變數會報錯。

3.物件

# 在下列情況下操作物件會報錯誤

  1. 為唯讀屬性賦值會報錯

  2. 對不可配置的屬性使用delete 會報錯

  3. 為不可擴充的物件新增屬性會報錯

  4. #在使用物件字面量的時候,屬性名稱必須唯一。例如

var person={
  name:"1",
  name:"2"
}

非嚴格模式下會預設取值第二個,嚴格模式下會報錯。

4.函數

# 嚴格模式要求函數參數名稱必須唯一

function(n,n){
  // todo
}

# 在非嚴格模式下,這個函數宣告不會報錯,透過參數名稱只能存取到第二個參數,第一個參數要透過arguments去存取。

arguments在兩種模式下也有所不同

# 在非嚴格模式下,修改命名參數的值會反映到arguments物件中,在嚴格模式下兩個值是獨立的。

淘汰了 arguments.callee(引用函數本身),arguments.caller(引用呼叫函數)。

嚴格模式下函數名稱不能使用js保留字

# **嚴格模式下只能在腳本的頂層和在函數內部聲明函數,在if語句中宣告函數會導致語法錯誤。 **

if(true){
  function(){
   // 严格模式下报错
}
}

5.this

# 在非嚴格模式下使用函數的apply(),call(),傳入null 或undefined值會轉換為全域物件。在嚴格模式下,函數的this始終是指定的值,無論指定的是什麼值。

var a="1";
function test(){
 console.log(this.a)
}
test.call(null) 在非严格模式下会输出1,严格模式下this就指代的就是null,null没有a属性,就会报错。

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

vue全域註冊與局部註冊使用詳解

readline怎麼逐行讀取並寫入內容

以上是怎麼使用JS嚴格模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn