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

相关推荐
星光不问赶路人2 分钟前
Node.js 如何判断入口文件:从 require.main 到 ES Module 实现
前端·node.js
Hello--_--World12 分钟前
Vue2的 双端 diff算法 与 Vue3 的 快速diff 算法
前端·vue.js·算法
gongzemin20 分钟前
怎么在VS Code 调试vue2 源码
前端·vue.js
烟话628 分钟前
Vue3响应式原理【通俗理解】
前端·javascript·vue.js
下北沢美食家30 分钟前
JavaScript面试题2
开发语言·javascript·ecmascript
浩星38 分钟前
electron系列5:深入理解Electron打包
前端·javascript·electron
患得患失94942 分钟前
【前端WebSocket】心跳功能,心跳重置策略、双向确认(Ping-Pong) 以及 指数退避算法(Exponential Backoff)
前端·websocket·算法
英俊潇洒美少年44 分钟前
React 实现 AI 流式打字机对话:SSE 分包粘包处理 + 并发优化
前端·javascript·react.js
chQHk57BN1 小时前
前端测试入门:Jest、Cypress等测试框架使用教程
前端
遇见你...1 小时前
前端技术知识点
前端