中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Javascript中嚴格模式use strict的示例分析

發布時間:2021-08-19 10:00:39 來源:億速云 閱讀:138 作者:小新 欄目:web開發

這篇文章給大家分享的是有關Javascript中嚴格模式use strict的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

嚴格模式:由ECMA-262規范定義的JavaScript標準,對javascrip的限制更強。

(非嚴格的模式,被稱為“馬虎模式/稀松模式/懶散模式”。)

一、嚴格模式的使用

嚴格模式可以在腳本或函數級別實現。(即全局和局部模式)

1.全局

在js文件的最前面添加    "use strict"

2.局部

在函數內部添加   "use strict",如下

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

二、嚴格模式和非嚴格模式的對比

1.嚴格模式下,無法刪除(delete)變量(delete是不合格的標識符))。非嚴格模式下會刪除失敗返回false

"use strict";
var x;
delete x;//報錯Delete of an unqualified identifier in strict mode.(不合格的標識符)

2.嚴格模式中,函數形參存在同名的,拋出錯誤; 非嚴格模式不會

嚴格模式下

function fn(a,a){
 "use strict";
  result=a+a;
  console.log(result);
}
fn(2,4);//Duplicate parameter name not allowed in this context(重復的參數名稱在此上下文中不允許)

非嚴格模式下

function fn1(a,a){
  "use strict";
  result=a+a;
  console.log(result);
}
fn1(2,4);//結果為8

3.嚴格模式不允許八進制整數直接量(如下)。非嚴格模式下不會報錯。

"use strict"
var x=089;
console.log(x);//報錯:Decimals with leading zeros are not allowed in strict mode.

4.嚴格模式中,arguments對象是傳入函數內實參列表的靜態副本(即不再追蹤參數的變化);非嚴格模式下,arguments對象里的元素和對應的實參是指向同一個值的引用。

嚴格模式下

fn(5);
function fn(a){
  "use strict";
  a = 42;
  // return a==arguments[0];//返回false
  console.log(a);//結果為42
  console.log(arguments[0]);//結果為5,嚴格模式下arguments[0]表示這個調用方法的第一個參數     (不再追蹤  參數的變化,在函數內部,參數a被重新賦值為42,但arguments[0]仍然為5.)
}

非嚴格模式下

fn(5);
function fn(a){
  a = 42;
  // return a==arguments[0];//返回true
  console.log(a);//結果為42
  console.log(arguments[0]);//結果為42(追蹤參數變化)

}

5.嚴格模式中 eval和arguments當做關鍵字,它們不能被賦值和用作變量聲明

"use strict";
var eval=3;//報錯:Unexpected eval or arguments in strict mode
var argument=6;//同樣報錯

6.嚴格模式會限制對調用棧的檢測能力,訪問arguments.callee,arguments.callee.caller會拋出異常

嚴格模式下:

"use strict";
function fn(n){
  if(n==0){
    return 1;
  }else{
    return n*arguments.callee(n-1);
  }
}
console.log(fn(5));//報錯

非嚴格模式下:

function fn(n){//階乘
  if(n==0){
    return 1;
  }else{
    return n*arguments.callee(n-1);
  }
}
console.log(fn(5));//正常120

caller:在一個函數調用另一個函數時,被調用函數會自動生成一個caller屬性,指向調用它的函數對象。如果該函數當前未被調用,或并非被其他函數調用,

則caller為null。如下:

嚴格模式下:

"use strict"
function fn1() {
  var n1= fn1.caller;
  console.log(n1);
}
function fn2() {
  fn1();
}
fn2();//報錯

非嚴格模式下:

function fn1() {
  var n1= fn1.caller;//此例中caller指向調用它的函數(fn2)
  console.log(n1);
}
function fn2() {
  fn1();
}
fn2();// 結果打印出:function fn2(){ fn1( ) };

7.嚴格模式變量必須先聲明,直接給變量賦值,不會隱式創建全局變量,不能用with。

嚴格模式下

"use strict";
with(obj){
  x;
}//報錯:Strict mode code may not include a with statement

解釋:道運行腳本時,首先是編譯,然后再執行。顯然在編譯的時候,所以就不能在編譯時確定with語句塊中的變量到底歸屬哪個對象。[with語句塊中的變量是(cl)的屬性

還是上一層變量作用域鏈中的變量。]。只能在執行時才能確定(c1)是Clothes的一個實例。這與嚴格模式有編譯時就檢查變量是否定義沖突,所以嚴格模式不會with語句的使用。

擴展:with語句的使用(用來引用某個特定對象中已有的屬性,但是不能用來給對象添加屬性。)

with(object instance)
{
  //代碼塊
}
eg:function Clothes(){
  this.color="red";
  this.size="m";
  this.price="cheap";
}
var c1=new Clothes();
with(c1){
  var str="顏色:"+color+",尺寸:"+size+",價格:"+price;
  document.write(str);
}//結果(顏色:red,尺寸:m,價格:cheap)

嚴格模式中 call apply傳入null undefined保持原樣不被轉換為window

感謝各位的閱讀!關于“Javascript中嚴格模式use strict的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩留县| 额尔古纳市| 锡林郭勒盟| 沁水县| 盈江县| 定兴县| 炉霍县| 依安县| 平南县| 万源市| 霍州市| 台南市| 平阴县| 文化| 龙井市| 论坛| 宕昌县| 深州市| 桃江县| 张掖市| 广汉市| 亳州市| 双峰县| 高安市| 浦县| 肥东县| 宜昌市| 凤阳县| 开江县| 彭泽县| 蓬安县| 望奎县| 岳普湖县| 曲阜市| 神池县| 日喀则市| 仪陇县| 呈贡县| 容城县| 兴海县| 遵化市|