關(guān)于this.$refs獲取不到dom的可能原因及解決方法
背景
搞餓了么高仿APP時,使用
this.$refs.wrapper.getElementsByClassName('food-list')
時獲取不到dom節(jié)點
正常能獲取到應(yīng)該是如下圖:
然后我又用了網(wǎng)上的方法:
this.$refs.foodList (foodList是li的dom節(jié)點)
結(jié)果還是刷新頁面時獲取不到dom
然后我對比了網(wǎng)友訪的餓了么的源碼,下面是網(wǎng)友的
下面是我的:
然后官網(wǎng)的解釋是:因為 ref 本身是作為渲染結(jié)果被創(chuàng)建的,在初始渲染的時候你不能訪問它們 - 它們還不存在
問題解決
1.在data里面寫上一個屬性
changValue=null
如下圖:
2.在mounted鉤子函數(shù)里寫一個超時調(diào)用
setTimeout(() => { //修改數(shù)據(jù) this.changValue = 1; //DOM還沒更新 this.$nextTick(() => { //DOM現(xiàn)在更新了 this.calculateHeight(); }); },0);
使得每次掛載完成時changValue這個屬性的值獲得改變,然后調(diào)用this.$nextTick()就可以更新DOM了。
其他例子:
如果是第一次打開模態(tài)框時無法獲取this.$refs,可以讓模態(tài)框打開時修改一個data對象中的值,然后執(zhí)行this.$nextTick()就可以更新DOM了。
3.測驗結(jié)果
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘)
這篇文章主要介紹了element中TimePicker時間選擇器禁用部分時間(顯示禁用到分鐘),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03何時/使用 Vue3 render 函數(shù)的教程詳解
這篇文章主要介紹了何時/使用 Vue3 render 函數(shù)的教程詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07