VUE3 ref 和 useTemplateRef

使用ref来绑定和获取

页面

javascript 复制代码
        <headerNav ref="headerNavRef"></headerNav>
        <div @click="showRef" ref="buttonRef">refbutton</div>

使用ref方法const后面的命名需要跟页面的ref值一样

javascript 复制代码
const buttonRef = ref('buttonRef')
const headerNavRef = ref('headerNavRef')
const showRef = () => {
    console.log(buttonRef.value,headerNavRef.value);
}

vue3.5 使用useTemplateRef 推荐

javascript 复制代码
const bRef = useTemplateRef('buttonRef')
const href = useTemplateRef('headerNavRef')
const showRef = () => {
    console.log(href.value,bRef.value);
}

当父组件想要通过 ref 获取自组件里面的内容 需要自组件主动暴露出去 ------defineExpose

javascript 复制代码
/**
 * defineExpose({xxxx,xxxx})
 */
defineExpose({
    navActive
})

如果你的vue不是3.5则需要更新vue的版本 可以去看另外一个文章
检查项目中的依赖是否有更新------npm outdated

相关推荐
源心锁12 小时前
👋 手搓 gzip 实现的文件分块压缩上传
前端·javascript
源心锁13 小时前
丧心病狂!在浏览器全天候记录用户行为排障
前端·架构
GIS之路13 小时前
GDAL 实现投影转换
前端
phltxy13 小时前
从零入门JavaScript:基础语法全解析
开发语言·javascript
烛阴13 小时前
从“无”到“有”:手动实现一个 3D 渲染循环全过程
前端·webgl·three.js
BD_Marathon13 小时前
SpringBoot——辅助功能之切换web服务器
服务器·前端·spring boot
Kagol13 小时前
JavaScript 中的 sort 排序问题
前端·javascript
eason_fan14 小时前
Service Worker 缓存请求:前端性能优化的进阶利器
前端·性能优化
光影少年14 小时前
rn如何和原生进行通信,是单线程还是多线程,通信方式都有哪些
前端·react native·react.js·taro
好大哥呀14 小时前
Java Web的学习路径
java·前端·学习