您的位置:首頁技術文章
文章詳情頁

javascript - 為什么Chrome里的console.log會有異步的表現

瀏覽:110日期:2023-03-16 16:00:12

問題描述

今天寫代碼的時候遇到了一個感覺很奇怪很詭異的問題

/** * Created by zhang on 5/26/2017. */var Wiw = function () { this.config = {'form':{ 'height':300, 'width':500},'content':'please edit you text!','handler':function () { //empty} } console.log(this.config);}Wiw.prototype = { ext:function (cfg) {console.log('2');$.extend(this.config,cfg);//執行合并 }}document.getElementById('a').onclick = function () { new Wiw().ext({form:{} })}

非常普通,首先new出來 初始化 然后調用合并方法 按道理說輸出的結果應該是 合并前的config屬性對象和合并后的 但實際的情況確是javascript - 為什么Chrome里的console.log會有異步的表現

他的表現就像是合并后再輸出 但是調用順序卻又是正常的

更加奇怪的是

當你把

console.log(this.config); 改成console.log(this.config.form)

結果又恢復了正常 javascript - 為什么Chrome里的console.log會有異步的表現

而在fireFox之中一直都很正常

javascript - 為什么Chrome里的console.log會有異步的表現

問題解答

回答1:

怎么說了,我覺得吧,chrome console的輸出內容,帶點實時,看截圖,盡管是后期改o的name,但這時候點開你看name怎么跟上面輸出的不一致了= =。也符合題主后面又說改成form怎么又正常了。 我覺得 就是 那個向下箭頭旁邊的屬于寫死的,點開內容則是實時的。

javascript - 為什么Chrome里的console.log會有異步的表現

另外一個問題:http://www.css88.com/jqapi-1....

var o = {form:{width:10}}$.extend(true, o,{form:{height:20}})

標簽: JavaScript
相關文章:
国产综合久久一区二区三区