Vue中動(dòng)態(tài)綁定Ref的兩種方式總結(jié)
前言
項(xiàng)目中ref綁定是常用的操作,那么如何實(shí)現(xiàn)動(dòng)態(tài)綁定ref并實(shí)現(xiàn)動(dòng)態(tài)獲取呢?動(dòng)態(tài)綁定的進(jìn)階寫法又該如何使用?
比如以下需求:
需求:用戶動(dòng)態(tài)創(chuàng)建多個(gè)空白表單,提交時(shí)需要獲取當(dāng)前所有表單數(shù)據(jù)。
一、方式一:利用模板字符串
以下方法定義 Ref 時(shí)定義到this.refs中的形式為數(shù)組,這里我們打印一下所有的ref:
可以看到打印的Ref為數(shù)組形式,因此在調(diào)用時(shí)應(yīng)該加上數(shù)組下標(biāo)
此代碼如下(示例):
// Html部分(定義Ref) :ref="'planRef'+item.id"或者 :ref="`planRef${item.id}`" // Js部分(回調(diào)Ref) this.$refs[`planRef${item.id}`][0].xxx;
二、方式二:利用箭頭函數(shù)傳入
1.基本聲明
在傳入 Ref 時(shí)直接傳入計(jì)算函數(shù),通過此函數(shù)再將創(chuàng)建的 Ref 保存到指定位置,在后續(xù)調(diào)用時(shí)就無需使用模板字符串,更直觀也更方便。
代碼如下(示例):
// Html部分(定義Ref) :ref="getPlanRef" // Js部分(定義Ref)、 // 定義存儲(chǔ)計(jì)劃Ref的位置,并且在回調(diào)時(shí)無需再使用this.$refs const planRef = ref([]); // 定義計(jì)算函數(shù)方法,將Ref存儲(chǔ) const getPlanRef = (el) => el && planRef.value.push(el);
2.回調(diào)Ref
在回調(diào)剛剛定義的 Ref 時(shí)直接通過xxx.value[ 下標(biāo) ]的形式即可
代碼如下(示例):
// index即為存儲(chǔ)時(shí)的順序 planRef.value[index].方法
3.Ref重復(fù)存儲(chǔ)問題
在實(shí)際使用時(shí),用戶動(dòng)態(tài)新增表單即動(dòng)態(tài)新增或刪除 Ref 時(shí) Vue 會(huì)觸發(fā)響應(yīng)更新 Dom ,而我們存儲(chǔ) Ref 的位置(planRef)并未重置,那么頁面更新后的 Ref 列表將會(huì)再次 Push 到 planRef 中,那么就會(huì)導(dǎo)致 planRef 中出現(xiàn)重復(fù)存儲(chǔ)的 Ref 。
解決思路一:在對(duì)Ref進(jìn)行新增或刪除操作時(shí)先刪除當(dāng)前存儲(chǔ)Ref位置的數(shù)據(jù),參考代碼如下:
// Ref新增方法 function addPlan() { // 清除存儲(chǔ)Ref位置的數(shù)據(jù),因?yàn)镈om改變會(huì)重新獲取 planRef.value.length = 0; // 新增空計(jì)劃表 planList.value.push( 表初始數(shù)據(jù) ); // 提示語 modal.msgSuccess('操作成功'); } // Ref刪除方法 function deletePlan(index) { // 清除存儲(chǔ)Ref位置的數(shù)據(jù),因?yàn)镈om改變會(huì)重新獲取 planRef.value.length = 0; // 移除需要?jiǎng)h除的計(jì)劃表 planList.value.splice(index, 1); // 提示語 modal.msgSuccess('操作成功'); }
解決思路二(未實(shí)踐):在 Html 部分利用聲明 key 值來避免所有 Dom 動(dòng)態(tài)更新,但刪除時(shí)就需要對(duì)存儲(chǔ) Ref 位置的數(shù)據(jù)進(jìn)行修改,將要?jiǎng)h除的 Ref 進(jìn)行移除,這個(gè)解決方法僅思路分享不知道是否可行。
附:ref在vfor中的使用
ref用在v-for內(nèi)部時(shí)通過this.$refs.name獲得的為一個(gè)數(shù)組,可知ref不同于id唯一標(biāo)識(shí),可以對(duì)同類型的dom采用相同的命名,通過vfor的下標(biāo)獲得具體指向的dom元素
<!-- ref='menuItem'--> <div ref="menuItem" class="menu_item" v-for="(item,index) in menuData" :key="item.id" @click="clickMenu(index)"> <div class="menu_item_title"> {{ item.name }} </div> </div>
export default { name: 'demo', components: {}, data() { return { menuData: [ {id: '0001', name: '菜單一'}, {id: '0002', name: '菜單二'}, {id: '0003', name: '菜單三'}, ], } }, watch: {}, computed: {}, created() { }, mounted() { console.log(this.$refs); }, methods: { clickMenu: function (index) { //this.$refs['menuItem'][0]、this.$refs['menuItem'][1]、this.$refs['menuItem'][2]分別對(duì)應(yīng)頁面三個(gè)dom console.log("點(diǎn)擊了下標(biāo):" + index, this.$refs['menuItem'][index]); } } }
總結(jié)
以上為實(shí)際項(xiàng)目中遇到的需求與思路,以及遇到的一些問題,希望我的分享對(duì)您有幫助。
到此這篇關(guān)于Vue中動(dòng)態(tài)綁定Ref的兩種方式的文章就介紹到這了,更多相關(guān)Vue動(dòng)態(tài)綁定Ref方式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue+webrtc(騰訊云) 實(shí)現(xiàn)直播功能的實(shí)踐
本文主要介紹了vue+webrtc(騰訊云) 實(shí)現(xiàn)直播功能的實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Vue3中shallowRef和shallowReactive的性能優(yōu)化
Vue3中shallowRef和shallowReactive是淺層響應(yīng)式API,用于性能優(yōu)化,僅追蹤對(duì)象或數(shù)組第一層屬性的變化,本文就來詳細(xì)的介紹一下具體的使用,感興趣的可以了解一下2024-09-09vue項(xiàng)目使用js監(jiān)聽瀏覽器關(guān)閉、刷新及后退事件的方法
這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目使用js監(jiān)聽瀏覽器關(guān)閉、刷新及后退事件的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09element-ui之關(guān)于組件BackToTop回到頂部的使用
這篇文章主要介紹了element-ui之關(guān)于組件BackToTop回到頂部的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03Vue3.0 響應(yīng)式系統(tǒng)源碼逐行分析講解
這篇文章主要介紹了Vue3.0 響應(yīng)式系統(tǒng)源碼逐行分析講解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10