Vue 讀取HTMLCollection列表的length為0問題
讀取HTMLCollection列表的length為0
在計算better-scroll右側(cè)列表滾動高度的時候,發(fā)現(xiàn)列表的length為0
原因
上網(wǎng)查閱發(fā)現(xiàn)問題可能是由于mounted 不會承諾所有的子組件也都一起被掛載。
這個時候dom元素還有沒掛載完畢。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:
mounted () { this.$nextTick(() => { this._initScroll(), this._calculateHeight(); }); },
但是不清楚為什么使用了這個方法后獲取的length依舊為0,
就在_calculateHeight()方法上加了個定時器,等到完全渲染完成時再獲取高度(這種問題可能會出現(xiàn)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解決
問題
在學(xué)習(xí)餓了么實踐項目時候發(fā)現(xiàn)一個問題,
在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 被新創(chuàng)建的 vm.$el 替換,并掛載到實例上去之后調(diào)用該鉤子。如果 root 實例掛載了一個文檔內(nèi)元素,當(dāng) mounted 被調(diào)用時 vm.$el 也在文檔內(nèi)。
注意 mounted 不會承諾所有的子組件也都一起被掛載。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:
mounted: function () { this.$nextTick(function () { // Code that will run only after the // entire view has been rendered }) }
該鉤子在服務(wù)器端渲染期間不被調(diào)用。
看完以上文檔介紹,可以知道在mounted階段,mounted 不會承諾所有的子組件也都一起被掛載,所以在此階段,dom結(jié)構(gòu)還沒加載完,js就執(zhí)行了
解決方案
1.使用官方文檔說明(如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 確保渲染完成后再獲取數(shù)據(jù)。
重要的是理解執(zhí)行順序,異步調(diào)用的話可以使用Promise保證執(zhí)行順序
踩到的一個坑:
有文章說可以在updated階段執(zhí)行,這時可以取到渲染完畢后的List
updated:由于數(shù)據(jù)更改導(dǎo)致的虛擬 DOM 重新渲染和打補丁,在這之后會調(diào)用該鉤子
就是說,在使用better-scroll滾動時,會觸發(fā)updated,使得scrollYList不斷被推入數(shù)據(jù),然后導(dǎo)致我用這個的時候,整個瀏
覽器崩潰了,很是尷尬,哈哈哈,所以我感覺updated執(zhí)行這個解決方案,不大適合解決這類問題
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決
這篇文章主要介紹了vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09vue3實戰(zhàn)-axios請求封裝問題(get、post、put、delete)
這篇文章主要介紹了vue3實戰(zhàn)-axios請求封裝問題(get、post、put、delete),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03vue項目中created()被調(diào)用多次的踩坑實戰(zhàn)
在vue項目中我在created中調(diào)用了兩次get數(shù)據(jù)請求,所以下面這篇文章主要給大家介紹了關(guān)于vue項目中created()被調(diào)用多次的踩坑實戰(zhàn),需要的朋友可以參考下2023-03-03vue.js添加一些觸摸事件以及安裝fastclick的實例
今天小編就為大家分享一篇vue.js添加一些觸摸事件以及安裝fastclick的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼功能
這篇文章主要介紹了 ruoyi-vue3 集成aj-captcha實現(xiàn)滑塊、文字點選驗證碼,本文基于后端RuoYi-Vue 3.8.7 和 前端 RuoYi-Vue3 3.8.7,集成以AJ-Captcha文字點選驗證碼為例,不需要鍵盤手動輸入,極大優(yōu)化了傳統(tǒng)驗證碼用戶體驗不佳的問題,感興趣的朋友一起看看吧2023-12-12