JS嚴格模式知識點總結
所謂嚴格模式其實就是一個不會賦值給任何變量的字符串 “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(引用調用函數(shù))。
嚴格模式下函數(shù)名不能使用js保留字
**嚴格模式下只能在腳本的頂級和在函數(shù)內部聲明函數(shù),在if語句中聲明函數(shù)會導致語法錯誤。**
if(true){
function(){
// 嚴格模式下報錯
}
}
5.this
在非嚴格模式下使用函數(shù)的apply(),call(),傳入null 或者undefined值會被轉換為全局對象。在嚴格模式下,函數(shù)的this始終是指定的值,無論指定的是什么值。
var a="1";
function test(){
console.log(this.a)
}
test.call(null) 在非嚴格模式下會輸出1,嚴格模式下this就指代的就是null,null沒有a屬性,就會報錯。
相關文章
javascript的document.referrer瀏覽器支持、失效情況總結
這篇文章主要介紹了javascript的document.referrer瀏覽器支持、失效情況總結,比較全面的對document.referrer在各個瀏覽器的支持情況、什么情況下會失效、Referer信息相關知識介紹等,需要的朋友可以參考下2014-07-07
Javascript中arguments和arguments.callee的區(qū)別淺析
這篇文章主要介紹了Javascript中arguments和arguments.callee的區(qū)別淺析,本文用一個實例來理解它們的區(qū)別,需要的朋友可以參考下2015-04-04
探討JavaScript中的Rest參數(shù)和參數(shù)默認值
這篇文章的主要介紹了JavaScript中的Rest參數(shù)和參數(shù)默認值,內容很充實,需要了解的朋友可以參考下2015-07-07

