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

相关推荐
漓漾li8 分钟前
每日面试题-前端2
前端·react.js·面试
Alice-YUE17 分钟前
深入解析 JS 事件循环:浏览器与 Node.js 的差异全解析
前端·javascript·笔记·学习
HYCS19 分钟前
用pixijs实现fabricjs(二):对象的基础位置信息
前端·javascript·canvas
淸湫22 分钟前
项目中使用了全局权限管理,请详细描述如何通过Vue Router的路由守卫来实现全局权限控制?
前端·vue.js
雪铃儿26 分钟前
Shorebird 之外,Flutter Android 热更新还有什么选择
android·前端
李剑一31 分钟前
前端必看 | Vue 刷新页面,生命周期钩子直接 "罢工",原来问题在这?90% 开发者都栽过!
前端·vue.js
閞杺哋笨小孩38 分钟前
域名驱动多租户入驻:后台配置 + 前端解析
前端·vue.js
TeamDev40 分钟前
在 Excel 加载项中嵌入 Web 视图
前端·后端·.net
悠哉摸鱼大王40 分钟前
cesium学习(一)-基本概念
前端·cesium
LinDaiDai_霖呆呆40 分钟前
大白话介绍大模型的一些底层原理,看完终于能跟人聊两句了
前端·人工智能·面试