第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

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

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

繁華開滿天機(jī) 2019-03-12 17:13:31
一直沒搞懂js的數(shù)據(jù)類型隱式轉(zhuǎn)換,像下面在控制臺(tái)輸出的例子,不知道是根據(jù)什么規(guī)則進(jìn)行轉(zhuǎn)換的:
查看完整描述

5 回答

?
largeQ

TA貢獻(xiàn)2039條經(jīng)驗(yàn) 獲得超8個(gè)贊

首先對(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é)果解釋起來就一句話,高程:


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

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


[].toString();//""

false.toString();//"false"

let o={};

o.toString();//"[object Object]"

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


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


如果你用來賦值,不會(huì)得到 0;;

如果你用來判斷 if(),也不會(huì)得到 0;;

甚至,function f(){ return {}+[];} f() 執(zhí)行也不會(huì)得到 0;

然后我們來說原因,經(jīng)過上面的例子,你怕也知道了為什么會(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ǔ)句來解析呢?測(cè)試下就知道了:


https://img1.sycdn.imooc.com//5c8ca0f40001122902590075.jpg


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


https://img1.sycdn.imooc.com//5c8ca0f700014ea602400071.jpg


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


{}

+[];

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


這是一元加操作符,高程上這么說:


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

https://img1.sycdn.imooc.com//5c8ca10000019fc001010046.jpg


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


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


完。

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


查看完整回答
反對(duì) 回復(fù) 2019-03-16
?
慕無(wú)忌1623718

TA貢獻(xiàn)1744條經(jīng)驗(yàn) 獲得超4個(gè)贊

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

個(gè)人見解,不對(duì)之處請(qǐng)大神包容指正,謝謝?。?/p>


查看完整回答
反對(duì) 回復(fù) 2019-03-16
?
炎炎設(shè)計(jì)

TA貢獻(xiàn)1808條經(jīng)驗(yàn) 獲得超4個(gè)贊

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


查看完整回答
反對(duì) 回復(fù) 2019-03-16
  • 5 回答
  • 0 關(guān)注
  • 619 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)