JS 嚴格模式

JS里有兩種運行模式,一種是正常運行模式,平時基本上用的也都是正常模式,另外一種是嚴格模式,strict mode,嚴格模式是ECMAscript 5添加,這種模式能讓JS在更嚴格的條件下運行
嚴格模式的提出有以下幾個目的:

1.消除了一些JS不合理,不嚴謹之處,減少一些怪異行為,保證代碼安全運行
2.提高了編譯器效率,增加運行速度
3.為未來新版本JS做好鋪墊

1.嚴格模式標志和使用

進入嚴格模式的標志,就是需要加上一個字符串:"use strict".如果是老版本的瀏覽器,像IE6789,就把這句話當成一句普通的字符串執行.
嚴格模式根據不同的作用域,有不同的調用方法

(1).針對整個腳本文件
將"use strict"放在腳本文件的第一行,則整個腳本都將以"嚴格模式"運行。如果這行語句不在第一行,則無效,整個腳本以"正常模式"運行。如果不同模式的代碼文件合并成一個文件,這一點需要特別注意。
第一種是針對整個腳本文件

<script>    
    "use strict";    
    console.log("這是嚴格模式。");  
</script>

第二種是針對單個函數,將"use strict"放在函數體的第一行,則整個函數以"嚴格模式"運行。

function strict(){    
    "use strict";    
    return "這是嚴格模式。";  
}

如果是放在自調用的匿名函數里話,用法也一樣,這種寫法主要是為了解決之前文件合并出現的問題.

(function (){
    "use strict";
 // some code here
})();

2.全局變量顯式聲明

在正常模式里,如果一個變量沒有聲明,那這個變量可以認為是全局變量,但是在嚴格模式下,這種寫法就會報錯,變量在使用之前,一定得先定義,全局變量.

"use strict";
v = 1; // 報錯,v未聲明
for(i = 0; i < 2; i++) { // 報錯,i未聲明
}

3.with語句

下面要用到這個with語句,先解釋一下.with語句能快速的使用一個對象的屬性,不需要每次都通過對象名.

function Lakers() {
    this.name = "龍哥";
    this.age = "18";
    this.gender = "boy";
}
var people = new Lakers();
with(people) {
    var str = "姓名: " + name;
    str += "年齡:" + age;
    str += "性別:" + gender;
    document.write(str);
}

用with語句相當于進入了people的內容去獲取屬性內容,在people這個對象的作用域中去使用屬性

4.嚴格模式禁止使用with語句

原因在于with語句在編譯的時候,沒有辦法確認這個傳進來的對象的歸屬,這種寫法在嚴格模式里是嚴格禁止的,只要在上面的例子最上面加上"use strict";在瀏覽器控制臺就會報錯

with語句報錯

嚴格模式不允許進行動態綁定,也就是要指明屬性和方法歸屬于哪個對象,在編譯階段就要確定.with就是違背了上述的要求

5.eval()函數

eval函數可以計算某個字符串,執行其中的JS代碼.eval()只需要一個參數,類型必須是字符串,如果參數不是字符串,則直接返回這個參數.如果是字符串,直接執行字符串對應的JS表達式和語句,如果有計算記過,eval()則會返回對應結果

eval("x=10;y=20;document.write(x*y)");
document.write(eval("2+2"));
var x=10;
document.write(eval(x+17));

接下來看一下eval關于作用域的問題

<script type="text/javascript"> 
    var test = function () { 
        eval("var i=3"); 
        alert(i); 
    } 
    test(); 
    alert(i); 
</script>

結果是首先彈出3,然后是undefined,eval()函數動態執行的代碼并不會創建新的作用域,其代碼就是在當前的作用域執行的。因此也就是說,eval()函數也完全可以使用當前作用域的this,argument等對象.
在IE里有一個根eval()函數很相似的函數,叫execScript(),作用大同小異,但是它有兼容問題,在Chrome和Firefox上不兼容,兼容的寫法跟addEventListener類似,就不寫了

6.嚴格模式設置了eval作用域

正常模式下,JS有三個作用域,一個是全局作用域,一個是函數函數作用域,在ES6里,已經有塊作用域了.嚴格模式創設了第三種作用域,就是eval作用域.在嚴格模式下,eval本身就是一個作用域,不再能夠生成全局變量了,它所生成的變量只能用于eval內部

"use strict";  
 var x = 2;  
 console.log(eval("var x = 5; x")); // 5
 console.log(x); // 2

7.重名錯誤

這里的重名只要值的是函數里不能有重復的形參名

"use strict";  
function f(a, a, b) { // 語法錯誤
    return;  
}

對象里有重復的屬性,不會報錯,答應的對象就會保留一個屬性,聲明重復變量名也不會報錯

8.禁止this指向全局變量

在函數里,this一般都指向是window這個全局變量,但是在嚴格模式下,this的值變為undefined.

function f() {    
    "use strict";
    console.log(this);  // undefined   
};

現在JS已經進入了ES6,有些內容會發生一點變化,比如之前會新增一些保留字,比如let,interface,implements等,都出現在ES6里.在接觸過RN等新技術之后大家會發現,嚴格模式用的還是比較多的.

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,825評論 6 546
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,814評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,980評論 0 384
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 64,064評論 1 319
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,779評論 6 414
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,109評論 1 330
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,099評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,287評論 0 291
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,799評論 1 338
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,515評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,750評論 1 375
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,221評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,933評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,327評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,667評論 1 296
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,492評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,703評論 2 380

推薦閱讀更多精彩內容

  • 一、概述 除了正常運行模式,ECMAscript 5添加了第二種運行模式:"嚴格模式"(strict mode)。...
    才気莮孒閱讀 201評論 0 1
  • "use strict"使用"use strict"指令的目的是說明(腳本或函數中)后續的代碼將會解析為嚴格代碼(...
    80bb3ef13dea閱讀 1,497評論 0 6
  • 通過嚴格模式,可以在函數內部 選擇進行較為嚴格的全局或局部的錯誤條件檢測。使用嚴格模式的好處是可以提早知道代碼中存...
    oWSQo閱讀 510評論 0 0
  • 'use strict' 是在一個嚴格的模式下 在正常模式中,如果一個變量沒有聲明就賦值,默認是全局變量。嚴格模式...
    FConfidence閱讀 272評論 0 0
  • 這款早餐制作比較耗時,但是原料豐富,成品也很漂亮,非常適合作為周末的早午餐。 原料: 培根兩片,法棍切片四片,雞蛋...
    Lisabao閱讀 278評論 0 0