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

相关推荐
百锦再1 分钟前
Vue中对象赋值问题:对象引用被保留,仅部分属性被覆盖
前端·javascript·vue.js·vue·web·reactive·ref
jingling5556 分钟前
面试版-前端开发核心知识
开发语言·前端·javascript·vue.js·面试·前端框架
拾光拾趣录11 分钟前
CSS 深入解析:提升网页样式技巧与常见问题解决方案
前端·css
莫空000012 分钟前
深入理解JavaScript属性描述符:从数据属性到存取器属性
前端·面试
guojl12 分钟前
深度剖析Kafka读写机制
前端
FogLetter13 分钟前
图片懒加载:让网页飞起来的魔法技巧 ✨
前端·javascript·css
Mxuan14 分钟前
vscode webview 插件开发(精装篇)
前端
Mxuan15 分钟前
vscode webview 插件开发(交付篇)
前端
Mxuan16 分钟前
vscode 插件与 electron 应用跳转网页进行登录的实践
前端
拾光拾趣录16 分钟前
JavaScript 加载对浏览器渲染的影响
前端·javascript·浏览器