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

相关推荐
瘦的可以下饭了7 小时前
3 链表 二叉树
前端·javascript
我那工具都齐_明早我过来上班7 小时前
WebODM生成3DTiles模型在Cesium地图上会垂直显示问题解决(y-up-to-z-up)
前端·gis
粉末的沉淀7 小时前
jeecgboot:electron桌面应用打包
前端·javascript·electron
1024肥宅7 小时前
浏览器相关 API:DOM 操作全解析
前端·浏览器·dom
烟西7 小时前
手撕React18源码系列 - Event-Loop模型
前端·javascript·react.js
空镜7 小时前
通用组件使用文档
前端·javascript
前端小张同学7 小时前
餐饮小程序需要你们
java·前端·后端
码农胖大海7 小时前
微前端架构(一):基础入门
前端