vue?this.$refs.xxx獲取dom注意事項(xiàng)?v-if?v-for渲染的dom不能直接使用
最近被借調(diào)到其他部門寫代碼,嘿嘿,我是一塊磚,哪里需要哪里搬……
今天遇到一個(gè)問題
vue項(xiàng)目:
v-for渲染的元素,如果內(nèi)容超過一行,則右側(cè)展示一個(gè)"更多"按鈕,點(diǎn)擊“更多”按鈕后,再展示全部的數(shù)據(jù)。


在上家公司的時(shí)候,我也遇到過類似的要求,但是當(dāng)時(shí)水平菜的底氣硬,直接一個(gè)不會(huì),愣是把需求改為了全部展示,今天遇到了這個(gè)問題,想著還是要解決一下,困難就是成長。
我的思路是
一行的內(nèi)容高度是50px,我只需要判斷渲染完成后,內(nèi)容區(qū)的高度是否超過50px即可。
于是:html部分代碼:
<div class="searchWrap">
<div class="searchItem" v-for="(tag, tagIndex) in pinPaiList" :key="tagIndex">
<div class="searchLeft">{{ tag.tagSortTitle }}</div>
<div class="searchList" :ref="'tagParent' + tagIndex">
<div v-for="(p, pIndex) in tag.items" :key="pIndex" class="listCls">
<span @click="selectPP(tagIndex, pIndex)" :class="{ active: p.checked }">{{ p.value | filterStr }}</span></div></div>
<div class="searchMore">
<div>
<div class="el-icon-arrow-down" v-if="tag.moreFlag" @click="moreData(tagIndex)">更多</div>
<div class="el-icon-circle-check" v-if="tag.selectMore" @click="sureSearch(tagIndex)"
:class="{ active: tag.selectMore }" >確定</div>
<div @click="changeType(tagIndex)" :class="{ active: tag.selectMore }" class="el-icon-circle-plus-outline">{{ !tag.selectMore ? "單選" : "多選" }}
</div>
</div>
</div>
</div>
</div>
上面代碼的重點(diǎn)在于,我要在v-for渲染的dom元素上綁定ref,動(dòng)態(tài)綁定屬性的方式跟其他的動(dòng)態(tài)綁定一致:
:ref="'tagParent' + tagIndex"
tag.moreFlag就是判斷是否要展示更多按鈕的關(guān)鍵,這個(gè)是根據(jù)dom元素的高度來判斷的。
vue項(xiàng)目中獲取dom元素的高度——this.$refs.xxx
vue項(xiàng)目中獲取dom元素的高度可以通過this.$refs.xxx的方式來處理:
但是我在使用的過程中,this.$refs.xxx的方式獲取dom,經(jīng)常會(huì)出現(xiàn)undefined,也有少數(shù)情況是可以獲取到的。
具體原因就是:如果是用v-if或者v-for渲染的dom元素,是不能直接使用this.$refs.xxx的方式來獲取dom的,即便是放在this.$nextTick里面也是不行的。
具體原因可以查看下面的鏈接:
http://www.dhdzp.com/article/279018.htm

具體的解決方法就是
需要在獲取到數(shù)據(jù)之后,再通過this.$nextTick的方式來處理:
我這邊的處理方法如下:
...
//此處的this.pinPaiList是從上面的接口中獲取到的數(shù)據(jù),需要循環(huán)遍歷,依次判斷高度
this.pinPaiList && this.pinPaiList.forEach((p, pIndex) => {
this.$nextTick(() => {
//一定要注意通過this.$refs.xxx的方式獲取到的dom要取index為0的一項(xiàng),然后獲取高度通過clientHight來獲取,如果不是v-if或者v-for渲染的dom,則不需要加這個(gè)0。
var height = this.$refs[`tagParent${pIndex}`][0].clientHeight;
if (height > 50) {
this.pinPaiList[pIndex].moreFlag = true;
//如果判斷出來某一項(xiàng)的高度超出一行,則延遲將此行的高度設(shè)置為一行,進(jìn)而展示更多按鈕,點(diǎn)擊更多按鈕時(shí)將height改為auto即可
setTimeout(() => {
this.$refs[`tagParent${pIndex}`][0].style.height = "35px";
}, 0);
} else {
this.pinPaiList[pIndex].moreFlag = false;
}
this.$set(this.pinPaiList, pIndex, this.pinPaiList[pIndex]);
});
});
...
//點(diǎn)擊更多按鈕
moreData(index) {
this.pinPaiList[index].moreFlag = false;
this.$set(this.pinPaiList, index, this.pinPaiList[index]);//這個(gè)是vue2的缺陷,數(shù)據(jù)改變視圖不渲染的解決方案
setTimeout(() => {
this.$refs[`tagParent${index}`][0].style.height = "auto";
}, 0);
}
問題解決?。?!
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vite分目錄打包及去掉默認(rèn)的.gz?文件的操作方法
Vite在默認(rèn)配置下會(huì)將資源打包至assets文件夾并添加哈希值,不同于Webpack的多文件夾存放方式,Vite只對(duì)public文件夾不進(jìn)行打包處理,而Webpack不打包public和static文件夾,本文介紹vite分目錄打包及去掉默認(rèn)的.gz?文件的操作方法,感興趣的朋友一起看看吧2024-09-09
Vue3項(xiàng)目中通過LuckySheet實(shí)現(xiàn)Excel在線編輯功能
在實(shí)現(xiàn)Excel文件導(dǎo)入時(shí),領(lǐng)導(dǎo)要求實(shí)現(xiàn)在前端導(dǎo)入文件后,不調(diào)用后端的接口,而是直接顯示excel文件的內(nèi)容,等待用戶修改完以后,再調(diào)用后端接口進(jìn)行文件的提交,所以本文介紹了Vue3項(xiàng)目中通過LuckySheet實(shí)現(xiàn)Excel在線編輯,需要的朋友可以參考下2025-04-04
使用Vue3和ApexCharts實(shí)現(xiàn)3D徑向條形圖的代碼
徑向條形圖是一種用于可視化單一數(shù)據(jù)點(diǎn)及其與目標(biāo)或理想值的關(guān)系的圖表類型,它在顯示進(jìn)度、完成率或其他類似度量時(shí)非常有用,本文給大家介紹了使用Vue3和ApexCharts實(shí)現(xiàn)3D徑向條形圖,感興趣的小伙伴可以參考閱讀下2024-06-06
Vue關(guān)鍵字搜索功能實(shí)戰(zhàn)小案例
在vue項(xiàng)目中,搜索功能是我們經(jīng)常需要使用的一個(gè)場景,下面這篇文章主要給大家介紹了關(guān)于Vue關(guān)鍵字搜索功能的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
如何使用 vxe-table 實(shí)現(xiàn)左邊是樹右邊是表格聯(lián)動(dòng)功能
使用 vxe-table 來實(shí)現(xiàn)左邊是樹,右邊是表格聯(lián)動(dòng)功能,當(dāng)需要實(shí)現(xiàn)左右兩側(cè)聯(lián)動(dòng)時(shí),表格 vxe-grid 配合分割模板 vxe-split 就很容易實(shí)現(xiàn)了,下面通過實(shí)例代碼給大家介紹使用 vxe-table 來實(shí)現(xiàn)左邊是樹,右邊是表格聯(lián)動(dòng)功能,感興趣的朋友一起看看吧2025-03-03
vue如何監(jiān)聽對(duì)象或者數(shù)組某個(gè)屬性的變化詳解
這篇文章主要給大家介紹了關(guān)于vue如何監(jiān)聽對(duì)象或者數(shù)組某個(gè)屬性的變化,在Vue.js中可以通過watch監(jiān)聽屬性變化并動(dòng)態(tài)修改其他屬性的值,watch通過監(jiān)聽器函數(shù)接收新舊值,實(shí)現(xiàn)屬性間的數(shù)據(jù)聯(lián)動(dòng),需要的朋友可以參考下2024-12-12

