javascript - 為什么Chrome里的console.log會有異步的表現
問題描述
今天寫代碼的時候遇到了一個感覺很奇怪很詭異的問題
/** * 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屬性對象和合并后的 但實際的情況確是
他的表現就像是合并后再輸出 但是調用順序卻又是正常的
更加奇怪的是
當你把
console.log(this.config); 改成console.log(this.config.form)
結果又恢復了正常
而在fireFox之中一直都很正常
問題解答
回答1:怎么說了,我覺得吧,chrome console的輸出內容,帶點實時,看截圖,盡管是后期改o的name,但這時候點開你看name怎么跟上面輸出的不一致了= =。也符合題主后面又說改成form怎么又正常了。 我覺得 就是 那個向下箭頭旁邊的屬于寫死的,點開內容則是實時的。
另外一個問題:http://www.css88.com/jqapi-1....
var o = {form:{width:10}}$.extend(true, o,{form:{height:20}})
相關文章:
1. javascript - js中遞歸與for循環同時發生的時候,代碼的執行順序是怎樣的?2. python - linux怎么在每天的凌晨2點執行一次這個log.py文件3. php如何獲取訪問者路由器的mac地址4. android - 鍵盤遮擋RecyclerView5. 如何分別在Windows下用Winform項模板+C#,在MacOSX下用Cocos Application項目模板+Objective-C實現一個制作游戲的空的黑窗口?6. javascript - jQuery each 方法第三個參數args 如何解釋?7. javascript - 在 vue里面用import引入js文件,結果為undefined8. java - new + 類名,一定需要申明一個對象嗎?9. 小程序怎么加外鏈,語句怎么寫!求救新手,開文檔沒發現10. javascript - vue-resource中如何設置全局的timeout?
