vue3组件ref属性用法,动态绑定ref

常见用法

TypeScript 复制代码
<template>
    <CustomWin  ref="sectionRef" class="ref-section"></CustomWin >
    <button @click="xx">点击</button>
</template>

<script setup lang="ts">
import {ref} from 'vue'
import CustomWin from "./CustomWin.vue"
const sectionRef = ref<InstanceType<typeof CustomWin>>();

function xx(){
    if(sectionRef.value){
       // sectionRef.value.xxx 调用
    }
}

</script>

如果我们需要在代码里面动态绑定ref,如果处理?

其实ref属性可以是个函数,(el)=>{},这样想怎样存储ref就可以怎样存储

TypeScript 复制代码
<template>
  <div v-for="(item, i) in list" :ref="el => { divs[i] = el }">
    {{ item }}
  </div>
</template>

<script>
import {
  onBeforeUpdate,
  reactive,
  ref,
} from 'vue';

export default {
  setup() {
    const list = reactive([1, 2, 3]);
    const divs = ref([]);

    // Make sure to reset the refs before each update.
    onBeforeUpdate(() => {
      divs.value = [];
    });

    return {
      list,
      divs,
    };
  },
};
</script>

注:el是就是vue实例,赋值后访问的时候无需xx.value

相关推荐
白嫖叫上我30 分钟前
Vue3封装主题色完善版
前端
a11177631 分钟前
细胞结构实验室(react 开源)
前端·javascript·开源·html
aaaak_32 分钟前
PDD 直播间 评论 , wss hex Protobuf 解析流程分析学习
java·前端·学习
ikoala39 分钟前
用了几周明基 RD280UG,我终于明白程序员为什么需要一台“专用显示器”
前端·后端·程序员
Dxy123931021641 分钟前
JS如何获取元素高度
开发语言·javascript·ecmascript
文心快码BaiduComate1 小时前
Comate搭载DeepSeek-V4
前端·后端
豹哥学前端1 小时前
5分钟搞懂事件委托
前端·javascript·面试
Awu12271 小时前
🍎把数学公式搬进 Web 表格:一个 VTable 实战案例
前端
江无行者1 小时前
aly oss技能应用
前端
朝阳391 小时前
单向数据流
前端