Vue2與Vue3中Ref綁定元素方式
Vue之Ref綁定元素獲取實例
我們可以通過給元素綁定ref屬性來獲取這個元素的實例,來調用實例中的某種方法來實現(xiàn)某種功能
Vue2實現(xiàn)
<template> <!-- 單個綁定 --> <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");//結果為單個對象 console.log(this.$refs.HelloArrRef, "HelloArrRef");// 結果為數(shù)組 }, methods: { }, };
在vue2寫法下,無論綁定單個元素或者循環(huán)綁定元素我們可以通過this.$refs.實例名稱
來獲取組件實例
Vue3實現(xiàn)
vue3中循環(huán)綁定ref是和vue2寫法略有不同,單個組件綁定寫法是一致的
<template> <!-- 單個綁定 --> <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需要先綁定一個方法通過這個方法獲取到實例保存在一個數(shù)組中
注意:
1.不必是數(shù)組:它也可以是一個對象,其 ref 可以通過迭代的 key 被設置。
2.如有需要,HelloRefArr 也可以是響應式的,且可以被偵聽。
在需要的時候通過這個數(shù)組去取。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
vue使用路由的query配置項時清除地址欄的參數(shù)案例詳解
這篇文章主要介紹了vue使用路由的query配置項時如何清除地址欄的參數(shù),本文通過案例給大家分享完美解決方案,需要的朋友可以參考下2023-09-09Vue利用computed解決單項數(shù)據(jù)流的問題
Vue是一個非常流行和強大的前端框架,它讓我們可以用簡潔和優(yōu)雅的方式來構建用戶界面,但是,Vue也有一些需要注意和掌握的細節(jié)和技巧,今天我們來分享一個Vue中非常經(jīng)典的問題,也是一個非常實用的技巧,Vue利用computed解決單項數(shù)據(jù)流,需要的朋友可以參考下2023-08-08