JS嚴(yán)格模式原理與用法實(shí)例分析
本文實(shí)例講述了JS嚴(yán)格模式原理與用法。分享給大家供大家參考,具體如下:
使用 "use strict" 指令
"use strict" 指令在 JavaScript 1.8.5 (ECMAScript5) 中新增。
它不是一條語(yǔ)句,但是是一個(gè)字面量表達(dá)式,在 JavaScript 舊版本中會(huì)被忽略。
支持嚴(yán)格模式的瀏覽器:
Internet Explorer 10 +、 Firefox 4+ Chrome 13+、 Safari 5.1+、 Opera 12+。
嚴(yán)格模式聲明
嚴(yán)格模式通過(guò)在腳本或函數(shù)的頭部添加 "use strict"; 表達(dá)式來(lái)聲明。
實(shí)例中我們可以在瀏覽器按下 F12 (或點(diǎn)擊"工具>更多工具>開(kāi)發(fā)者工具") 開(kāi)啟調(diào)試模式,查看報(bào)錯(cuò)信息。
為什么使用嚴(yán)格模式:
- 消除Javascript語(yǔ)法的一些不合理、不嚴(yán)謹(jǐn)之處,減少一些怪異行為;
- 消除代碼運(yùn)行的一些不安全之處,保證代碼運(yùn)行的安全;
- 提高編譯器效率,增加運(yùn)行速度;
- 為未來(lái)新版本的Javascript做好鋪墊。
嚴(yán)格模式的限制
1、不允許使用未聲明的變量;
2、不允許刪除變量或?qū)ο螅?/p>
3、不允許刪除函數(shù);
4、不允許變量重名;
5、不允許使用八進(jìn)制;
6、不允許使用轉(zhuǎn)義字符;
7、不允許對(duì)只讀屬性賦值;
8、不允許對(duì)一個(gè)使用getter方法讀取的屬性進(jìn)行賦值;
9、不允許刪除一個(gè)不允許刪除的屬性;
10、變量名不能使用'eval'字符串;
11、變量名不能使用'arguments'字符串;
12、不允許使用以下這種語(yǔ)句:
<script>
"use strict";
with (Math){x = cos(2)}; // 報(bào)錯(cuò)
</script>
13、由于一些安全原因,在作用域 eval() 創(chuàng)建的變量不能被調(diào)用:
<script>
"use strict";
eval ("var x = 2");
alert (x); // 報(bào)錯(cuò)
</script>
14、禁止this關(guān)鍵字指向全局對(duì)象。
function f(){
return !this;
}
// 返回false,因?yàn)?this"指向全局對(duì)象,"!this"就是false
function f(){
"use strict";
return !this;
}
// 返回true,因?yàn)閲?yán)格模式下,this的值為undefined,所以"!this"為true。
感興趣的朋友還可以使用本站在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行結(jié)果。
更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專(zhuān)題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript 引用類(lèi)型實(shí)例詳解【數(shù)組、對(duì)象、嚴(yán)格模式等】
- JavaScript 嚴(yán)格模式(use strict)用法實(shí)例分析
- javascript嚴(yán)格模式詳解(含嚴(yán)格模式與非嚴(yán)格模式的區(qū)別)
- 在JavaScript中使用嚴(yán)格模式(Strict Mode)
- JavaScript變量提升和嚴(yán)格模式實(shí)例分析
- 深入淺析JS中的嚴(yán)格模式
- JS嚴(yán)格模式知識(shí)點(diǎn)總結(jié)
- JavaScript嚴(yán)格模式下關(guān)于this的幾種指向詳解
- 深入理解javascript嚴(yán)格模式(Strict Mode)
- JavaScript嚴(yán)格模式不支持八進(jìn)制的問(wèn)題講解
相關(guān)文章
使用CSS3的scale實(shí)現(xiàn)網(wǎng)頁(yè)整體縮放
QQ郵箱的網(wǎng)頁(yè)整體縮放效果,原來(lái)實(shí)現(xiàn)方法如此簡(jiǎn)單,下面有個(gè)實(shí)現(xiàn)示例,大家可以參考下2014-03-03
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開(kāi)始讀秒倒計(jì)時(shí)的小例子
js實(shí)現(xiàn)點(diǎn)擊注冊(cè)按鈕開(kāi)始讀秒倒計(jì)時(shí)的小例子,需要的朋友可以參考一下2013-05-05
JS控件bootstrap datepicker使用方法詳解
這篇文章主要介紹了js控件bootstrap datepicker的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
解決layui laydate 時(shí)間控件一閃而過(guò)的問(wèn)題
今天小編就為大家分享一篇解決layui laydate 時(shí)間控件一閃而過(guò)的問(wèn)題,具有好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
通過(guò)Javascript讀取本地Excel文件內(nèi)容的代碼示例
這篇文章主要介紹了通過(guò)Javascript讀取本地Excel文件內(nèi)容的代碼示例,但需要一定的條件才可以使用js操作本地文件,需要的朋友參考下吧2014-04-04
詳解CommonJS和ES6模塊循環(huán)加載處理的區(qū)別
這篇文章主要介紹了詳解CommonJS和ES6模塊循環(huán)加載處理的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12
JavaScript代碼實(shí)現(xiàn)圖片循環(huán)滾動(dòng)效果
這篇文章主要介紹了JavaScript代碼實(shí)現(xiàn)圖片循環(huán)滾動(dòng)效果的相關(guān)資料,非常不錯(cuò),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
mock.js模擬數(shù)據(jù)實(shí)現(xiàn)前后端分離
這篇文章主要為大家詳細(xì)介紹了mock.js模擬數(shù)據(jù)實(shí)現(xiàn)前后端分離,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07

