JS嚴格模式知識點總結(jié)
所謂嚴格模式其實就是一個不會賦值給任何變量的字符串 “use strict”
如果在全局作用域下 給出這個提示,那整個腳本將采用嚴格模式。也可以只在函數(shù)中打開嚴格模式
1.嚴格模式下沒有全局變量
a="test"
嚴格模式下會報錯,非嚴格模式下正常
2.刪除變量
var 有三種聲明的情形
- var 聲明的全局變量
- var 聲明的局部變量
- eval()中聲明的全局變量
第一種和第二種情況是無法用 delete刪掉的。
首先第一種情況聲明的全局對象雖然是windows的屬性,但這個屬性的configurable=false 因此是無法刪除的
第二種情況 局部變量更不行了,連依附的對象是誰都不知道,怎么刪除
第三種情況eval()稍后會說到。
回歸正題。也就是說非嚴格模式下,可以刪除變量,但是會失敗返回false.
嚴格模式下刪除變量會報錯。
3.對象
在下列情況下操作對象會報錯
- 為只讀屬性賦值會報錯
- 對不可配置的屬性使用delete 會報錯
- 為不可擴展的對象添加屬性會報錯
- 在使用對象字面量的時候,屬性名必須唯一。比如
var person={ name:"1", name:"2" }
非嚴格模式下會默認取值第二個,嚴格模式下會報錯。
4.函數(shù)
嚴格模式要求函數(shù)參數(shù)名稱必須唯一
function(n,n){ // todo }
在非嚴格模式下,這個函數(shù)聲明不會報錯,通過參數(shù)名只能訪問到第二個參數(shù),第一個參數(shù)得通過arguments去訪問。
arguments在兩種模式下也有所不同
在非嚴格模式下,修改命名參數(shù)的值會反映到arguments對象中,在嚴格模式下兩個值是獨立的。
淘汰了 arguments.callee(引用函數(shù)本身),arguments.caller(引用調(diào)用函數(shù))。
嚴格模式下函數(shù)名不能使用js保留字
**嚴格模式下只能在腳本的頂級和在函數(shù)內(nèi)部聲明函數(shù),在if語句中聲明函數(shù)會導致語法錯誤。**
if(true){ function(){ // 嚴格模式下報錯 } }
5.this
在非嚴格模式下使用函數(shù)的apply(),call(),傳入null 或者undefined值會被轉(zhuǎn)換為全局對象。在嚴格模式下,函數(shù)的this始終是指定的值,無論指定的是什么值。
var a="1"; function test(){ console.log(this.a) } test.call(null) 在非嚴格模式下會輸出1,嚴格模式下this就指代的就是null,null沒有a屬性,就會報錯。
相關(guān)文章
javascript的document.referrer瀏覽器支持、失效情況總結(jié)
這篇文章主要介紹了javascript的document.referrer瀏覽器支持、失效情況總結(jié),比較全面的對document.referrer在各個瀏覽器的支持情況、什么情況下會失效、Referer信息相關(guān)知識介紹等,需要的朋友可以參考下2014-07-07Javascript中arguments和arguments.callee的區(qū)別淺析
這篇文章主要介紹了Javascript中arguments和arguments.callee的區(qū)別淺析,本文用一個實例來理解它們的區(qū)別,需要的朋友可以參考下2015-04-04探討JavaScript中的Rest參數(shù)和參數(shù)默認值
這篇文章的主要介紹了JavaScript中的Rest參數(shù)和參數(shù)默認值,內(nèi)容很充實,需要了解的朋友可以參考下2015-07-07