這篇文章為大家整理了JS嚴格模式下的相關知識點以及程式碼實例分享,感興趣的一起學習下吧。
所謂嚴格模式其實就是一個不會賦值給任何變數的字串 “use strict”
如果在全域作用域下 給出這個提示,那整個腳本將採用嚴格模式。也可以只在函數中開啟嚴格模式
1.嚴格模式下沒有全域變數
a="test"
嚴格模式下會報錯,非嚴格模式下正常
2.刪除變數
#var 有三種宣告的情形
3.物件
在下列情況下操作物件會報錯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属性,就会报错。上面是我整理給大家的,希望今後會對大家有幫助。 相關文章:
透過JS中利用FileReader如何實作上傳圖片前本機預覽功能
以上是詳細講解JS嚴格模式知識點有哪些?的詳細內容。更多資訊請關注PHP中文網其他相關文章!