摘要:開啟嚴格模式設置對象是一個不可擴展的對象為對象新增屬性張無忌在非嚴格模式下為不可擴展的對象添加新屬性,結果是靜默失敗。
概述 嚴格模式是什么
嚴格模式是JavaScript中的一種限制性更強的變種方式。嚴格模式不是一個子集:它在語義上與正常代碼有著明顯的差異。
不支持嚴格模式的瀏覽器與支持嚴格模式的瀏覽器行為上也不一樣,所以不要在未經嚴格模式特性測試情況下使用嚴格模式。
嚴格模式可以與非嚴格模式共存,所以腳本可以逐漸的選擇加入嚴格模式。
首先嚴格模式會將JavaScript陷阱直接變成明顯的錯誤。
其次就是嚴格模式修正了一些引擎以優化的錯誤:同樣的代碼有時候嚴格模式會比非嚴格模式下更加流暢。
然后,嚴格模式禁用了一些有可能在未來版本中定義的語法。
如果想要在JavaScript中開啟嚴格模式,首先要在所有代碼的最前面,定義一個不會賦給任何變量的字符串。
如果之前的JavaScript代碼是非嚴格模式的話,建議不要盲目的為這段代碼開啟嚴格模式,這樣可能會出現問題。在初學時期建議按一個個的函數去開啟嚴格模式。
// 開啟嚴格模式 - 作用于全局作用域 // "use strict" // 定義一個變量 - 不使用var關鍵字 a = 100; //在非嚴格模式中可以不使用var關鍵字,但是嚴格模式不可以,不然就會報錯。 console.log(a); function fn(){ // 開啟嚴格模式 - 作用于函數作用域 "use strict" v = 200; console.log(v); } fn();函數開啟嚴格模式
嚴格模式也可以為一個指定的函數開啟。
function fn(){ "use strict" //在函數體中開啟嚴格模式,但是函數意外依舊是非嚴格模式 v = 200; consolo.log(v); } fn();變量 禁止意外創建變量
在嚴格模式的情況下,是不允許創建全局變量的。
// 開啟嚴格模式 "use strict"; v = 100;//不使用var關鍵字 console.log(v); function fn(){ // 在非嚴格模式:在函數作用域中定義變量 - 不使用var關鍵字 -> 自動將其提升為全局變量 w = 200; console.log(w); } fn(); console.log(w);靜默失敗轉為異常
所謂的靜默失敗就是即不報錯也沒有任何效果。例如改變常量的值。在嚴格模式下,靜默失敗會轉換成拋出異常。
// 開啟嚴格模式 "use strict"; const v = 3.14;// 定義常量 v = 1.14;// 重新賦值。嚴格模式下結果報錯。 console.log(v);禁用delete關鍵字
在嚴格模式下,不能使用變量使用delete運算符,但是這種情況只針對變量,對數組和對象屬性沒有限制。
// 開啟嚴格模式 "use strict"; // 嚴格模式下禁用delete關鍵字 -> 針對刪除變量,而不是數組元素和對象屬性 // var v = 100;// 定義一個全局變量 // console.log(v); // // delete v;// 刪除全局變量v // console.log(v);// undefined 定義數組 // var arr = [1,2,3,4,5]; // delete arr[0]; // console.log(arr); 定義對象 var obj = { name : "張無忌" } delete obj.name; console.log(obj.name);對變量名的限制
在嚴格模式下,JavaScript對變量名也有限制。特別不能使用如下內容作為變量:
上述內容都是保留字,在ECMAScript的下一個版本中可能會用到他們。
但是在嚴格模式下,使用上述標示符作為變量名會導致語法錯誤。
// 開啟嚴格模式 "use strict"; var static = 100; console.log(static);//結果-報錯對象 不可刪除的屬性
在嚴格模式下,不能使用delete運算符刪除不可刪除的屬性。
開啟嚴格模式 "use strict"; //在非嚴格模式下使用delete刪除不可刪除的屬性 delete Object.prototype;//結果會靜默失敗 console.log(Object.prototype); //在嚴格模式下使用delete刪除不可刪除額屬性,結果就是拋出異常。 delete Math.random; console.log(Math.random); // Math.random();屬性名必須唯一
在嚴格模式下,一個對象的所有屬性名在對象內必須唯一。
// 開啟嚴格模式 "use strict"; //在非嚴格模式下重名是允許的,最后一個重名的屬性就會覆蓋以上的屬性 //當開啟嚴格模式,重名屬性就會被認為是語法錯誤 var obj = { name : "張三", name : "李四" } console.log(obj.name);只讀屬性的賦值
在嚴格模式下,不能為一個只讀的屬性進行重新賦值。
// 開啟嚴格模式 "use strict"; var obj = { name : "張無忌" } // 用于判斷指定屬性是否為只讀屬性 var result = Object.getOwnPropertyDescriptor(obj, "name"); console.log(result);//在非嚴格模式下為只讀屬性重新賦值,結果會為靜默失敗。 // 定義對象obj的只讀屬性 Object.defineProperty(obj, "age", { value : 18 }); // 針對只讀屬性進行修改操作 // obj.age = 80; // console.log(obj.age); delete obj.age; console.log(obj.age);不可擴展的對象
在嚴格模式下,不能為不可擴展的對象添加新屬性。
// 開啟嚴格模式 "use strict"; var obj = {}; // 設置對象obj是一個不可擴展的對象 Object.preventExtensions(obj); // 為對象obj新增屬性 obj.name = "張無忌"; console.log(obj); //在非嚴格模式下為不可擴展的對象添加新屬性,結果是靜默失敗。函數 參數名必須唯一
在嚴格模式下,要求命名函數的參數必須唯一。
// 開啟嚴格模式 "use strict"; function fn(a, a, b){ console.log(a + a + b); //在非嚴格模式下最后一個參數名就會之前的重名參數,之前的參數仍然可以銅鼓arguments[i]來訪問。 //在開啟嚴格模式下,重名參數就會被認為是語法錯誤。 } fn(1,2,3);arguments的不同
在嚴格模式下,arguments對象的行為也有所不同。
1.在非嚴格模式下,修改命名參數的值也會反應到arguments對象中。
2.在嚴格模式下,命名參數與arguments對象是完全獨立的。
// 開啟嚴格模式 "use strict"; function fn(value){ var value = "張無忌"; console.log(value);// 張無忌 -> 就近原則 /* * 非嚴格模式下 - arguments對象獲取參數的值與形參有關的 * 如果局部變量與形參名相同 - 根據就近原則進行獲取 * 嚴格模式下 - arguments對象獲取參數的值與形參無關的 */ console.log(arguments[0]);// 張無忌 } fn("周芷若");arguments.callee()
在嚴格模式下,不能使用arguments對象的callee()方法。
// 開啟嚴格模式 "use strict"; //在非嚴格模式下,arguments對象callee()方法,表示調用函數本身 // 在嚴格模式下,arguments對象無法調用callee()方法,結果拋出異常 function fn(){ console.log(arguments.length); // return arguments.callee; } fn();函數聲明的限制
在嚴格模式下,只能在全局域和函數域中聲明函數。
// 開啟嚴格模式 "use strict"; // 在全局作用域 function fn(){ // 在函數作用域 function n(){} //在非嚴格模式下,函數的定義在人格位置聲明函數都是可以的。 } // 在嚴格模式下,函數的定義只能在全局作用域與函數作用域(不能在塊級作用域定義函數),語法錯誤 for (var i=0; i<10; i++) { // ECMAScript 6新增 - 存在著塊級作用域 var v = 100; function f(){ console.log("this is function"); } } console.log(v); f();eval()函數 增加eval()作用域
在嚴格模式下使用eval()函數創建的變量只能在eval()函數內部使用。
// 開啟嚴格模式 "use strict"; //在非嚴格模式下eval()函數創建的變量在其他位置可以使用。 // 在嚴格模式下,增加eval作用域 - eval()函數定義的變量只能在當前eval()函數內部使用 eval("var v = 100;"); // 在全局作用域中調用變量 - 報錯 console.log(v);// 100arguments對象 禁止讀寫
在嚴格模式下,禁止使用eval()和arguments作為標示符,也不允許讀寫它們的值。
1.使用var聲明
2.賦值另一個值
3.嘗試修改包含的值
4.用作函數名
5.用作命名的函數的參數
6.在try...catch語句中用作例外明
// 開啟嚴格模式 "use strict"; //在嚴格模式下,以下所有嘗試都導致語法錯誤 eval = 17; arguments++; ++eval; var obj = { set p(arguments) { } }; var eval; try { } catch (arguments) { } function x(eval) { } function arguments() { } var y = function eval() { }; var f = new Function("arguments", ""use strict"; return 17;");this關鍵字 抑制this
在非嚴格模式下使用函數的apply()或call()方法時,null或undefined值會被轉換為全局對象。
在嚴格模式下,函數的this值始終是指定的值(無論什么值)。
// 開啟嚴格模式 "use strict"; var v = 100; function fn(){ console.log(this.v); } var obj = { v : 200 } fn.call(obj);// this指向全局對象
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/96987.html
摘要:嚴格模式嚴格模式的概念所謂嚴格模式就是對中的一種限制性更強的方式屬于代碼的一種強制規則來規范代碼的格式簡單的說就是必須按照嚴格模式的規則書寫代碼否則就會報錯嚴格模式修正了一些引擎難以優化的錯誤同樣的代碼有些時候嚴格模式會比非嚴格模式下更加快 嚴格模式 嚴格模式的概念 所謂嚴格模式就是對JavaScript中的一種限制性更強的方式. 屬于代碼的一種強制規則,來規范代碼的格式簡單的說就是...
摘要:嚴格模式描述嚴格模式可以分別作用在全局作用域中和函數作用域中嚴格模式是對代碼的一種限制方式嚴格模式可以將不明確顯示的錯誤轉變成明確顯示嚴格模式可以修正一些解釋器難以優化的錯誤嚴格模式下的變量禁止意外創建變量沒有開啟嚴格模式時在調用該變量時, 嚴格模式 描述 嚴格模式可以分別作用在全局作用域中和函數作用域中 嚴格模式是對JavaScript代碼的一種限制方式 嚴格模式可以將不明確顯...
摘要:一嚴格模式概述嚴格模式是什么在中是種限制性更強變種方式,不是個子集,在語義上與正常代碼有明顯得差異嚴格模式和非嚴格模式可共存,可選擇性的加入嚴格模式嚴格模式的目的將把陷阱直接變為明顯錯誤修正一些引擎難以優化錯誤,代碼有些時候嚴格模式會比非嚴 JS(JavaScript)一.嚴格模式1.概述 嚴格模式是什么 在JS中是種限制性更強變種方式,不是個子集,在語義上與正常代碼有明顯得差異嚴格模...
摘要:上一篇面向對象版塊之理解對象下一篇面向對象版塊之定義多個對象屬性以及讀取屬性特性 這是 javascript 面向對象版塊的第二篇文章,主要講解的是對象的屬性,首先創建一個對象: var person = { name: Nicholas, age: 29, job: Software Engineer, sayName: function () { conso...
摘要:面向對象編程對象的原生方法分成兩類自身的方法靜態方法和的實例方法。的靜態方法方法與,參數是對象,返回一個數組,數組的值是改對象自身的所有屬性名區別在于返回可枚舉的屬性,返回不可枚舉的屬性值。 面向對象編程 Objects對象的原生方法分成兩類:Object自身的方法(靜態方法)和Object的實例方法。注意Object是JavaScript的原生對象,所有的其他對象都是繼承自Objec...
閱讀 2578·2021-11-22 09:34
閱讀 944·2021-11-19 11:34
閱讀 2805·2021-10-14 09:42
閱讀 1482·2021-09-22 15:27
閱讀 2388·2021-09-07 09:59
閱讀 1737·2021-08-27 13:13
閱讀 3436·2019-08-30 11:21
閱讀 777·2019-08-29 18:35