Vue2與Vue3中Ref綁定元素方式
Vue之Ref綁定元素獲取實(shí)例
我們可以通過(guò)給元素綁定ref屬性來(lái)獲取這個(gè)元素的實(shí)例,來(lái)調(diào)用實(shí)例中的某種方法來(lái)實(shí)現(xiàn)某種功能
Vue2實(shí)現(xiàn)
<template> <!-- 單個(gè)綁定 --> <HelloWorld ref="HelloRef" /> <!-- 循環(huán)綁定 --> <div v-for="item in arr" :key="item"> <hello-world ref="HelloArrRef"></hello-world> </div> </template>
<script> import HelloWorld from "./components/HelloWorld.vue"; export default { name: "App", components: { HelloWorld, }, data() { return { count:0 }; }, mounted() { console.log(this.$refs.HelloRef, "HelloRef");//結(jié)果為單個(gè)對(duì)象 console.log(this.$refs.HelloArrRef, "HelloArrRef");// 結(jié)果為數(shù)組 }, methods: { }, };
在vue2寫(xiě)法下,無(wú)論綁定單個(gè)元素或者循環(huán)綁定元素我們可以通過(guò)this.$refs.實(shí)例名稱(chēng)
來(lái)獲取組件實(shí)例
Vue3實(shí)現(xiàn)
vue3中循環(huán)綁定ref是和vue2寫(xiě)法略有不同,單個(gè)組件綁定寫(xiě)法是一致的
<template> <!-- 單個(gè)綁定 --> <HelloWorld ref="HelloRef" /> <!-- 循環(huán)綁定 --> <div v-for="item in arr" :key="item"> <hello-world :ref="setItemRef"></hello-world> </div> </template>
<script> import HelloWorld from "./components/HelloWorld.vue"; import { defineComponent, onMounted,onBeforeUpdate,onUpdated, ref } from "vue"; export default defineComponent({ name: "App", components: { HelloWorld, }, setup() { const HelloRef = ref(null); const arr = ref([1, 2, 3]); const HelloRefArr = ref([]); const setItemRef = (el) => { if (el) { HelloRefArr.value.push(el); } }; onMounted(() => { console.log(HelloRef.value, "HelloRef"); console.log(HelloRefArr.value, "HelloRefArr"); }); onBeforeUpdate(() => { HelloRefArr.value = [] }) onUpdated(() => { console.log(HelloRefArr.value,' HelloRefArr.value--update') }) return { HelloRef, arr, setItemRef, HelloRefArr, }; }, }); </script>
在vue3中循環(huán)綁定元素,與vue2不同是 ref需要先綁定一個(gè)方法通過(guò)這個(gè)方法獲取到實(shí)例保存在一個(gè)數(shù)組中
注意:
1.不必是數(shù)組:它也可以是一個(gè)對(duì)象,其 ref 可以通過(guò)迭代的 key 被設(shè)置。
2.如有需要,HelloRefArr 也可以是響應(yīng)式的,且可以被偵聽(tīng)。
在需要的時(shí)候通過(guò)這個(gè)數(shù)組去取。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解vantUI框架在vue項(xiàng)目中的應(yīng)用踩坑
這篇文章主要介紹了詳解vantUI框架在vue項(xiàng)目中的應(yīng)用踩坑,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12vue使用路由的query配置項(xiàng)時(shí)清除地址欄的參數(shù)案例詳解
這篇文章主要介紹了vue使用路由的query配置項(xiàng)時(shí)如何清除地址欄的參數(shù),本文通過(guò)案例給大家分享完美解決方案,需要的朋友可以參考下2023-09-09vue 做移動(dòng)端微信公眾號(hào)采坑經(jīng)驗(yàn)記錄
這篇文章主要介紹了vue 做移動(dòng)端微信公眾號(hào)采坑經(jīng)驗(yàn)記錄,文中是小編記錄的三個(gè)坑及解決方案,需要的朋友可以參考下2018-04-04Vue利用computed解決單項(xiàng)數(shù)據(jù)流的問(wèn)題
Vue是一個(gè)非常流行和強(qiáng)大的前端框架,它讓我們可以用簡(jiǎn)潔和優(yōu)雅的方式來(lái)構(gòu)建用戶(hù)界面,但是,Vue也有一些需要注意和掌握的細(xì)節(jié)和技巧,今天我們來(lái)分享一個(gè)Vue中非常經(jīng)典的問(wèn)題,也是一個(gè)非常實(shí)用的技巧,Vue利用computed解決單項(xiàng)數(shù)據(jù)流,需要的朋友可以參考下2023-08-08Vue動(dòng)態(tài)組件與異步組件超詳細(xì)講解
這篇文章主要介紹了Vue動(dòng)態(tài)組件與異步組件,動(dòng)態(tài)組件是根據(jù)數(shù)據(jù)的變化,可以隨時(shí)切換不同的組件,比如咱們現(xiàn)在要展示一個(gè)文本框和輸入框,我們想要根據(jù)我們data中定義的值去決定是顯示文本框還是輸入框2023-03-03vue中用H5實(shí)現(xiàn)文件上傳的方法實(shí)例代碼
本篇文章主要介紹了vue中用H5實(shí)現(xiàn)文件上傳的方法實(shí)例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05vue連接本地服務(wù)器的實(shí)現(xiàn)示例
本文主要介紹了vue連接本地服務(wù)器的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01