Vue2与Vue3中Ref绑定元素
vue中ref绑定元素
·
Vue之Ref绑定元素获取实例
- 我们可以通过给元素绑定ref属性来获取这个元素的实例,来调用实例中的某种方法来实现某种功能
Vue2实现
<template>
<!-- 单个绑定 -->
<HelloWorld ref="HelloRef" />
<!-- 循环绑定 -->
<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");// 结果为数组
},
methods: {
},
};
在vue2写法下,无论绑定单个元素或者循环绑定元素我们可以通过this.$refs.实例名称
来获取组件实例
Vue3实现
vue3中循环绑定ref是和vue2写法略有不同,单个组件绑定写法是一致的
<template>
<!-- 单个绑定 -->
<HelloWorld ref="HelloRef" />
<!-- 循环绑定 -->
<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中循环绑定元素,与vue2不同是 ref需要先绑定一个方法通过这个方法获取到实例保存在一个数组中( 注意:1.不必是数组:它也可以是一个对象,其 ref 可以通过迭代的 key 被设置。2.如有需要,HelloRefArr 也可以是响应式的,且可以被侦听。
)在需要的时候通过这个数组去取。
更多推荐
已为社区贡献1条内容
所有评论(0)