vue2通过$refs调用子组件方法

问题描述

提示:这里简述项目相关背景:

父组件更新筛选项时,需要重置子组件相关参数。使用$refs时使用this.$refs['productCostTableRef'].resetFn('resName') 的写法,发生以下报错:

但是该方法在调用elementui 组件时不会报错。

html 复制代码
<el-popover ref="popover-ref">
</el-popover>
js 复制代码
this.$refs["popover-ref"].doClose(); // 成功执行popover关闭的事件

原因分析:

ref 写在标签上时:this.$refs.名字 / this.$refs['名字'] 获取的是标签对应的dom元素

ref 写在组件上时:这时候获取到的是子组件的引用


解决方案:

使用$ref调用自定义子组件的方法时,要用this.$refs.refName.methodsName();去调用。

另外几种使用情形:

传参时:this.$refs.refName.methodsName('参数值');

获取参数值: this.$refs.refName.dataName

修改参数值: this.$refs.refName.dataName = newData

相关推荐
zadyd11 小时前
Workflow or ReAct ?
前端·react.js·前端框架
北寻北爱13 小时前
vue2和vue3使用less和scss
前端·less·scss
IT_陈寒13 小时前
Redis性能提升3倍的5个冷门技巧,90%开发者都不知道!
前端·人工智能·后端
雨雨雨雨雨别下啦13 小时前
Vue案例——面经
前端·javascript·vue.js
oo1213814 小时前
里程碑5 - 完成框架 npm 包抽象封装并发布
前端·npm
达拉14 小时前
我花了三天用AI写了个上一代前端构建工具
前端·前端工程化
bysking14 小时前
【31-Ai-Agent】ai-agent的核心实现细节-bysking
前端
从文处安14 小时前
「前端何去何从」(React教程)React 状态管理:从局部 State 到可扩展架构
前端·react.js
一拳不是超人14 小时前
Three.js一起学-如何通过官方例子高效学习 Three.js?手把手带你“抄”出一个3D动画
前端·webgl·three.js
椰子皮啊14 小时前
400行Node.js搞定mediasoup信令转换:一次跨语言"表白"实录
前端·架构