欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

什么是JavaScript中的結(jié)果值?

 更新時間:2016年10月08日 15:22:17   作者:蘇福  
你知道JavaScript中的結(jié)果值是什么嗎?這篇文章主要介紹了JavaScript結(jié)果值,感興趣的小伙伴們可以參考一下

你知道JavaScript中的每條語句、甚至表達(dá)式都有一個結(jié)果值嗎?

當(dāng)你在瀏覽器中測試代碼時,經(jīng)常會在控制臺的輸出結(jié)果的最后面多出一條,大部分為undefined,這個undefined就是一個結(jié)果值。

ES7的do表達(dá)式

先從ES7的一個提案說起吧:do表達(dá)式do{...}(注意:不是do{...}while();中的do)

var a,b,c = 3;
a = do {
   if (true) {
      b = c*3;
   }
};
a; //9 目前的瀏覽器暫不支持

表達(dá)式do{...}的作用就是返回它后面的語句塊的結(jié)果值,功能其實(shí)和return類似,只不過return需要通過函數(shù)來封裝后調(diào)用。

不過目前來說,我們還無法使用上面的功能,目前的規(guī)范是不允許我們獲得語句的結(jié)果值并將其賦值給一個變量的(除了使用eval(),如var a = eval('if (true) {b = c*3;}'),a的值被賦值為eval()內(nèi)的語句的結(jié)果值,不建議使用eval())。

ES5規(guī)范關(guān)于結(jié)果值的規(guī)定

現(xiàn)在你應(yīng)該大概理解了什么是結(jié)果值了,本人翻看了ES5規(guī)范,發(fā)現(xiàn)JavaScript中,語句塊、語句、甚至表達(dá)式都會隱式地返回一個結(jié)果值,總結(jié)如下:
結(jié)果值是語句、表達(dá)式經(jīng)過邏輯運(yùn)算后的值,若無邏輯(按順序執(zhí)行)則為最后一條子語句、表達(dá)式的結(jié)果值(語句可以包含子語句),簡單地說它就是一個語句、表達(dá)式的“隱式的返回值”,JavaScript會計算每一條語句、表達(dá)式并返回一個結(jié)果值,而對于語句塊的結(jié)果值,它是最后一條最外層語句的結(jié)果值(非嵌套的子語句)。

部分瀏覽器會在控制臺輸出一段代碼的最后一條語句或語句塊的結(jié)果值(本文所有代碼均使用Firefox測試,不同瀏覽器有差別)

結(jié)果值可以為任何表達(dá)式的值,也可以為空(;、break;、continue;),為空時結(jié)果值為undefined。當(dāng)結(jié)果值為空時,瀏覽器會忽略該語句,而打印出上一條同級的非空的語句,若僅有自身一條同級語句則打印出undefined。

特例:var變量聲明語句、函數(shù)聲明語句的結(jié)果值為undefined。

1、變量聲明語句算法的返回值實(shí)際為表示該變量名稱的字符串,但是這個值被變量語句算法屏蔽掉了(for...in循環(huán)除外),最后返回結(jié)果為undefined
2、而對于函數(shù)聲明語句,它的結(jié)果值本人按規(guī)范解讀為該函數(shù)對象,但瀏覽器顯示為undefined,具體什么原因,本人還不理解(可能是因為函數(shù)只是定義,未被實(shí)際執(zhí)行的原因);
3、函數(shù)執(zhí)行語句的結(jié)果值為:
3.1 若有throw語句,則為throw語句的結(jié)果值
3.1 若有return語句,則為return語句的結(jié)果值
3.2 若無throw、return語句則為undefined

例子:

var a,b,c = 3;
if (true) {b = c*3;} //按順序執(zhí)行到最后一條語句,輸出9
; //undefined 單獨(dú)的空語句
var d = 5; //undefined 所有的var聲明語句的結(jié)果值均為undefined

function foo(a){
 a = a+2;
 return a;
}
//undefined 函數(shù)聲明語句的最終結(jié)果值也為undefined
foo(1); //3 函數(shù)執(zhí)行語句的結(jié)果值為函數(shù)throw、return語句的結(jié)果值,若無throw、return語句,則為undefined
if(true){a=1;}else{b=2;} //1 按邏輯計算結(jié)果執(zhí)行a=1;語句

{
 var a = 1,b = 2;
 if(true){a;}else{b;} //輸出1,最后一條空語句會被忽略
 ;
}
var a = 5;
switch(a){
 case 1:
  a+1;
  break;
 case 5:
  a+5;
  break;
 case 3:
  a+3;
  break;
}
//10 空的break;語句會被忽略
var a = 5;
switch(a){
 case 1:
  a+1;
  break;
 case 5:
  break; //執(zhí)行這里,它這里無同級語句
 case 3:
  a+3;
  break;
}
//undefined 

下面來具體看看表達(dá)式的結(jié)果值有什么用:
大部分表達(dá)式只有結(jié)果值,沒有副作用,如:var a = 2; var b = a + 3;,這里的表達(dá)式a+3的結(jié)果值為5,被賦值給了b。

而有副作用的表達(dá)式,如:

function foo(){
  a++;
}
var a=0;
foo(); //結(jié)果值為undefined,副作用是改變了a的值

又如:

var a = 0; 
var b = a++;
a; //1
b; //0
var c = a++; //結(jié)果值為undefined 副作用是c被賦值了,a變成了2 
var d = a++, a; //結(jié)果值為undefined,副作用是d被賦值為2,a變成了3,實(shí)際執(zhí)行的是var d = a++;
var d = (a++,a);//結(jié)果值為undefined,副作用是d被賦值為3,a變成了3,實(shí)際執(zhí)行的是var d = ++a;
function foo(){
  var e = f = 1;  //表達(dá)式f=1的結(jié)果值為1,1又被賦值給e
}
foo();
f; //1 創(chuàng)建了全局變量f
e; //ReferenceError

賦值語句的副作用是將'='右邊的表達(dá)式的結(jié)果值賦值給了左邊的變量,最終整個賦值語句的結(jié)果值為變量的值,為此我們可以這樣:

function foo(a){
  var b;
  if(a&&(b = a*10;)<50){
    ...
  }
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • js的window.showModalDialog及window.open用法實(shí)例分析

    js的window.showModalDialog及window.open用法實(shí)例分析

    這篇文章主要介紹了js的window.showModalDialog及window.open用法,實(shí)例分析了window.showModalDialog與window.open方法的定義、功能與使用技巧,需要的朋友可以參考下
    2015-01-01
  • 微信小程序可滑動周日歷組件使用詳解

    微信小程序可滑動周日歷組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了微信小程序可滑動周日歷組件的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • 詳解JavaScript類型判斷的四種方法

    詳解JavaScript類型判斷的四種方法

    這篇文章主要介紹了JavaScript類型判斷的四種方法,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-10-10
  • 微信小程序滾動、輪播圖和文本實(shí)例詳解

    微信小程序滾動、輪播圖和文本實(shí)例詳解

    輪播圖是我們?nèi)粘i_發(fā)中經(jīng)常會遇到的一個需求,下面這篇文章主要給大家介紹了關(guān)于微信小程序滾動、輪播圖和文本的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • js中設(shè)置元素class的三種方法小結(jié)

    js中設(shè)置元素class的三種方法小結(jié)

    列舉所有的方式,看看各瀏覽器的支持差異。方便用js動態(tài)設(shè)置元素css的代碼。需要的朋友可以參考下。
    2011-08-08
  • 原生JS生成九宮格

    原生JS生成九宮格

    這篇文章主要為大家詳細(xì)介紹了原生JS生成九宮格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • JavaScript命名空間模式實(shí)例詳解

    JavaScript命名空間模式實(shí)例詳解

    這篇文章主要介紹了JavaScript命名空間模式,結(jié)合實(shí)例形式分析了javascript命名空間模式的相關(guān)概念、原理、實(shí)現(xiàn)方法及操作注意事項,需要的朋友可以參考下
    2019-06-06
  • 獲取css樣式表內(nèi)樣式的js函數(shù)currentStyle(IE),defaultView(FF)

    獲取css樣式表內(nèi)樣式的js函數(shù)currentStyle(IE),defaultView(FF)

    JS從樣式表取值的函數(shù),IE中以currentStyle,firefox中defaultView來獲取,需要的朋友可以參考下。
    2011-02-02
  • JavaScript函數(shù)返回值的具體使用

    JavaScript函數(shù)返回值的具體使用

    本文主要介紹了JavaScript函數(shù)返回值,包括基本返回值、多返回值、異步函數(shù)的返回值等,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • javascript實(shí)現(xiàn)禁止復(fù)制網(wǎng)頁內(nèi)容匯總

    javascript實(shí)現(xiàn)禁止復(fù)制網(wǎng)頁內(nèi)容匯總

    本文給大家匯總介紹了幾種使用javascript和CSS實(shí)現(xiàn)禁止復(fù)制頁面內(nèi)容的方法,非常的實(shí)用,有需要的小伙伴可以參考下。
    2015-12-12

最新評論