Vue 讀取HTMLCollection列表的length為0問題
讀取HTMLCollection列表的length為0
在計算better-scroll右側列表滾動高度的時候,發現列表的length為0
原因
上網查閱發現問題可能是由於mounted 不會承諾所有的子組件也都一起被掛載。
這個時候dom元素還有沒掛載完畢。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:
mounted () { this.$nextTick(() => { this._initScroll(), this._calculateHeight(); }); },
但是不清楚為什麼使用瞭這個方法後獲取的length依舊為0,
就在_calculateHeight()方法上加瞭個定時器,等到完全渲染完成時再獲取高度(這種問題可能會出現bug,不知道頁面什麼時候渲染完畢):
_calculateHeight () { setTimeout(() => { let foodList = this.$refs.right.getElementsByClassName('food-list-hook'); let height = 0; this.listHeight.push(height); for (var i = 0; i < foodList.length; i++) { let item = foodList[i]; height += item.clientHeight; this.listHeight.push(height); } }, 200) },
無法讀取HTMLCollection列表的length解決
問題
在學習餓瞭麼實踐項目時候發現一個問題,
在mounted階段,獲取Element對象,console.log()可以讀取出列表,而卻無法讀出它的length
如下
let foodList = this.$refs.menuWrapper.getElementsByClassName('calculate-content') let height = 0 console.log(foodList) console.log(foodList.length) for (var i = 0; i < foodList.length; i++) { height += foodList[i].clientHeight this.scrollYList.push(height) }
原因
以下出自官方文檔
mounted
- 類型:Function
- 詳細:
- el 被新創建的 vm.$el 替換,並掛載到實例上去之後調用該鉤子。如果 root 實例掛載瞭一個文檔內元素,當 mounted 被調用時 vm.$el 也在文檔內。
註意 mounted 不會承諾所有的子組件也都一起被掛載。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:
mounted: function () { this.$nextTick(function () { // Code that will run only after the // entire view has been rendered }) }
該鉤子在服務器端渲染期間不被調用。
看完以上文檔介紹,可以知道在mounted階段,mounted 不會承諾所有的子組件也都一起被掛載,所以在此階段,dom結構還沒加載完,js就執行瞭
解決方案
1.使用官方文檔說明(如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 確保渲染完成後再獲取數據。
重要的是理解執行順序,異步調用的話可以使用Promise保證執行順序
踩到的一個坑:
有文章說可以在updated階段執行,這時可以取到渲染完畢後的List
updated:由於數據更改導致的虛擬 DOM 重新渲染和打補丁,在這之後會調用該鉤子
就是說,在使用better-scroll滾動時,會觸發updated,使得scrollYList不斷被推入數據,然後導致我用這個的時候,整個瀏
覽器崩潰瞭,很是尷尬,哈哈哈,所以我感覺updated執行這個解決方案,不大適合解決這類問題
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- vue使用better-scroll實現橫向滾動的方法實例
- 在vue.js渲染完界面之後如何再調用函數
- Vue中利用better-scroll組件實現橫向滾動功能
- Vue nextTick獲取更新後的DOM的實現
- Vue中的nextTick作用和幾個簡單的使用場景