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

javascript連續(xù)賦值問(wèn)題

 更新時(shí)間:2015年07月08日 11:00:48   投稿:hebedich  
本文通過(guò)具體的示例來(lái)給大家詳細(xì)解釋了下javascript的連續(xù)賦值問(wèn)題,十分的實(shí)用,有需要的小伙伴可以參考下。

前幾天在搜索面試題時(shí)發(fā)現(xiàn)了這么一段代碼,執(zhí)行完后感覺(jué)完全不與所想的一樣

 var a = {
   n : 1
 };
 var b = a;
 a.x = a = {n : 2};
 console.log(a.x);
 console.log(b.x);

輸出結(jié)果為:

undefined

[object Object]

一開(kāi)始以為語(yǔ)句應(yīng)該是先給 a 賦值 {n : 2} , 然后再將 a.x 賦值 {n : 2} ;

但事實(shí)卻不是那樣,于是改動(dòng)了一下代碼,添加幾條log

var test;
var a = {
  get test () {
    console.log("call a get");
    return test;
  },
  set test (value) {
    console.log("call a set");
    test = value;
  }
}
var test2;
var b = {
  get test2 () {
    console.log("call b get");
    return test2;
  },
  set test2 (value) {
    console.log("call b set");
    test2 = value;
  }
}
a.test = {
  n : 1
};
b.test2 = a.test;
console.log("begin");
a.test.x = a.test = {n : 2};

這樣,在begin后邊,這條賦值到底執(zhí)行了什么就一目了然了.

這是語(yǔ)句執(zhí)行時(shí)打印的log

先觸發(fā)了一次get,然后觸發(fā)了一次set.

本人猜想,該條語(yǔ)句執(zhí)行的順序?yàn)?先將左邊變量取出,然后執(zhí)行賦值.(在執(zhí)行該條語(yǔ)句前,先將對(duì)象引用取出,然后從右到左執(zhí)行賦值)


以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡

相關(guān)文章

最新評(píng)論