在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問(wèn)答/HTML/ js數(shù)據(jù)類(lèi)型隱式轉(zhuǎn)換

js數(shù)據(jù)類(lèi)型隱式轉(zhuǎn)換

一直沒(méi)搞懂js的數(shù)據(jù)類(lèi)型隱式轉(zhuǎn)換,像下面在控制臺(tái)輸出的例子,不知道是根據(jù)什么規(guī)則進(jìn)行轉(zhuǎn)換的:
clipboard.png
求解答

回答
編輯回答
赱丅呿

1.復(fù)雜對(duì)象隱式轉(zhuǎn)換應(yīng)該是調(diào)用toString方法了,空數(shù)組toString就是空字符串,空對(duì)象toString就是"[object, Object]"。
2.那個(gè)花括號(hào)寫(xiě)在最前面會(huì)單獨(dú)是當(dāng)一個(gè)塊級(jí)作用域(es6)來(lái)解析了(控制臺(tái)直接輸入{}.toString()是會(huì)報(bào)錯(cuò)的,就是當(dāng)作塊級(jí)作用域了,沒(méi)有那個(gè)方法),由此就相當(dāng)于 + []了,+號(hào)就把它轉(zhuǎn)成number了
3.加括號(hào)的話(huà)很好理解呀,提高優(yōu)先級(jí),看成一個(gè)整體,就不會(huì)把花括號(hào)單獨(dú)解析了

個(gè)人見(jiàn)解,不對(duì)之處請(qǐng)大神包容指正,謝謝??!

2017年9月11日 12:53
編輯回答
伴謊

首先對(duì)題主放截圖不放代碼的行為表示強(qiáng)烈譴責(zé)?。?!

然后擺結(jié)果,有歧義的備注//歧義了:

let d1 = false + []; //false
let d2 = [] + false; //false
let d3 = false + {}; //false[object Object]
let d4 = {} + false; //[object Object]false//歧義
let d5 = [] + {}; //[object Object]
let d6 = {} + []; //[object Object]//歧義
let d7 = ({} + []); //[object Object]
let d8 = ([] + {}); //[object Object]

console.log(d1);
console.log(d2);
console.log(d3);
console.log(d4);
console.log(d5);
console.log(d6);
console.log(d7);
console.log(d8);

上面的結(jié)果解釋起來(lái)就一句話(huà),高程:

如果有一個(gè)操作數(shù)是對(duì)象、數(shù)值或布爾值,則調(diào)用它們的toString()方法取得相應(yīng)的字符串值,然后再應(yīng)用前面關(guān)于字符串的規(guī)則

如果要分析的話(huà),加上下面的就可以了:

[].toString();//""
false.toString();//"false"
let o={};
o.toString();//"[object Object]"

現(xiàn)在再來(lái)說(shuō),和題主的截圖有兩個(gè) 0 不一致的地方;

首先題主截圖沒(méi)問(wèn)題,我測(cè)試了,我上面的結(jié)果也沒(méi)問(wèn)題,也測(cè)試了;但是在平常應(yīng)用中,應(yīng)該遇不到那種情況,比方說(shuō) {}+[]

  1. 如果你用來(lái)賦值,不會(huì)得到 0;;
  2. 如果你用來(lái)判斷 if(),也不會(huì)得到 0;;
  3. 甚至,function f(){ return {}+[];} f() 執(zhí)行也不會(huì)得到 0;

然后我們來(lái)說(shuō)原因,經(jīng)過(guò)上面的例子,你怕也知道了為什么會(huì)不一致了;

賦值=、if()、return 后面跟的都是表達(dá)式,上述歧義的括號(hào)版本,返回的就是預(yù)期內(nèi)的數(shù)據(jù),因?yàn)槔ㄌ?hào)里放的也是表達(dá)式;

{} + false//0
{} + []//0
({} + [])//[object Object]
([] + {})//[object Object]

那么當(dāng)瀏覽器在遇到 { 時(shí),是把它當(dāng)表達(dá)式還是語(yǔ)句來(lái)解析呢?測(cè)試下就知道了:

clipboard.png

很明顯是當(dāng)成語(yǔ)句來(lái)解析的,如果當(dāng)成一個(gè)空對(duì)象的表達(dá)式來(lái)解析,那么空對(duì)象是有 toString 方法的,再不濟(jì),也應(yīng)該是返回 undefined(非嚴(yán)格模式,瀏覽器端);在這種表達(dá)式和語(yǔ)句有歧義的地方,一般加個(gè) () 就可以將語(yǔ)句轉(zhuǎn)為表達(dá)式,所以,下圖是不報(bào)錯(cuò)的,并且返回正確:

clipboard.png

那么繼續(xù),既然是 { 當(dāng)成語(yǔ)句來(lái)解析,那么{}+[]實(shí)際相當(dāng)于語(yǔ)句{}后面跟了一條無(wú)關(guān)緊要的表達(dá)式而已+[],也就是這樣:

{}
+[];

所以題主在控制臺(tái)執(zhí)行{}+[],實(shí)際上是返回了最后一條語(yǔ)句的結(jié)果+[],為什么這個(gè)結(jié)果是 0 呢?

這是一元加操作符,高程上這么說(shuō):

在對(duì)非數(shù)值應(yīng)用一元加操作符時(shí),該操作符會(huì)像Number()轉(zhuǎn)型函數(shù)一樣對(duì)這個(gè)值執(zhí)行轉(zhuǎn)換

clipboard.png

所以:{}+[]=>{};+[]; 最終返回 Number([]);

同理:{} + false=>{};+false;,最終返回 Number(false);

完。

JavaScript高級(jí)程序設(shè)計(jì)-第3版-中

2017年11月24日 13:11
編輯回答
苦妄

一、先去了解 + 加號(hào)運(yùn)算符在 js 中的使用規(guī)律。
二、如果在空對(duì)象加上圓括號(hào)(()),這樣JS就會(huì)認(rèn)為它是個(gè)對(duì)象
三、網(wǎng)上有很多關(guān)于轉(zhuǎn)換的有趣的總結(jié),可以去看看

2017年12月20日 00:20
編輯回答
青檸

可以參考文章js隱式裝箱ToPrimitive

2017年3月3日 06:52
編輯回答
紓惘
2017年10月22日 04:15