vue 父组件通过$refs获取子组件的值和方法详解


Posted in Javascript onNovember 07, 2019

前言

在vue项目中组件之间的通讯是很常见的问题,同时也是很重要的问题,我们大致可以将其分为三种情况:

父传子:在父组件中绑定值,在子组件中用props接收

子传父:在父组件中监听一个事件,在子组件中利用$emit触发这个事件并带上数据作为第二个参数,这时父组件中监听事件的回调函数就会被调用,回调函数的参数就是子组件带上来的数据,这样就可以在父组件中使用子组件的数据了,

兄弟之间的传递:我们可以使用事件总线(eventBus)来轻松的解决,其实就是发布订阅者模式

今天我们要看的是父组件如何直接调取子组件的数据和方法,而不是通过子组件传上来的

在这里我们要理解父组件直接拿事件是在父组件上,子组件传上来数据,事件是在子组件上,是完全不同的两种情况

代码展示

子组件 children.vue,我们在子组件中定义了数据sonData和方法sonMethod

// children.vue

<template>
 <div>我是 children</div>
</template>

<script>
export default {
 data: () => ({
  sonData: '我是子组件的数据!'
 }),
 methods: {
  sonMethod() {
   console.log('我是子组件的方法!')
  }
 },
 computed: {
  
 },
 created() {

 }
}
</script>

父组件 文件

// 父组件

<template>
 <div>
  <children ref='ch'>
  </children>
  <h1 @click="onclick">父组件</h1>
 </div>
</template>

<script>
import children from './coms/children'
export default {
 data() {
  return {}
 },
 components: {
  children
 },
 methods: {
  onclick() {
  // 或者 let chil = this.$refs['ch']
   let chil = this.$refs.ch

  // 父组件可以通过$refs拿到子组件的对象
  // 然后直接调用子组件的 methods里的方法和data里的数据
   console.log(chil) //子组件对象
   console.log(chil.sonData) // 我是子组件的数据
   console.log(chil.sonMethod()) // 我是子组件的方法
  }
 }
}
</script>

注意事项

因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!,所以它不是响应式的,不能用在模板或者计算属性中。

以上这篇vue 父组件通过$refs获取子组件的值和方法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
修改jQuery.Autocomplete插件 支持中文输入法 避免TAB、ENTER键失效、导致表单提交
Oct 11 Javascript
基于jquery的图片幻灯展示源码
Jul 15 Javascript
JS函数重载的解决方案
May 13 Javascript
两种方法实现在HTML页面加载完毕后运行某个js
Jun 16 Javascript
jQuery+CSS3+Html5实现弹出层效果实例代码(附源码下载)
May 16 Javascript
好好了解一下Cookie(强烈推荐)
Jun 14 Javascript
Select2.js下拉框使用小结
Oct 24 Javascript
JS 全屏和退出全屏详解及实例代码
Nov 07 Javascript
javascript常用经典算法详解
Jan 11 Javascript
JQuery Ajax 异步操作之动态添加节点功能
May 24 jQuery
详解vue-cil和webpack中本地静态图片的路径问题解决方案
Sep 27 Javascript
浅谈JS中几种轻松处理'this'指向方式
Sep 16 Javascript
vue基本使用--refs获取组件或元素的实例
Nov 07 #Javascript
浅谈Vue中render中的h箭头函数
Nov 07 #Javascript
基于JavaScript伪随机正态分布代码实例
Nov 07 #Javascript
Vue 通过公共字段,拼接两个对象数组的实例
Nov 07 #Javascript
vue之a-table中实现清空选中的数据
Nov 07 #Javascript
vue实现将一个数组内的相同数据进行合并
Nov 07 #Javascript
jQuery利用cookie 实现本地收藏功能(不重复无需多次命名)
Nov 07 #jQuery
You might like
国外比较好的几个的Php开源建站平台小结
2010/04/22 PHP
PHP SPL标准库之SplFixedArray使用实例
2015/05/12 PHP
PHP基于GD库的图像处理方法小结
2016/09/27 PHP
PHP实现Session入库/存入redis的方法
2017/05/04 PHP
php微信公众号开发之校园图书馆
2018/10/20 PHP
Javascript 设计模式(二) 闭包
2010/05/26 Javascript
jQuery插件原来如此简单 jQuery插件的机制及实战
2012/02/07 Javascript
常见的原始JS选择器使用方法总结
2014/04/09 Javascript
基于jQuery实现的扇形定时器附源码下载
2015/10/20 Javascript
JavaScript常用基础知识强化学习
2015/12/09 Javascript
总结JavaScript三种数据存储方式之间的区别
2016/05/03 Javascript
使用Bootstrap美化按钮实例代码(demo)
2017/02/03 Javascript
JS异步加载的三种实现方式
2017/03/16 Javascript
Vue.js 实现微信公众号菜单编辑器功能(二)
2018/05/08 Javascript
Nodejs实现爬虫抓取数据实例解析
2018/07/05 NodeJs
Vue+Django项目部署详解
2019/05/30 Javascript
jquery实现下载图片功能
2019/07/18 jQuery
Node.js 中如何收集和解析命令行参数
2021/01/08 Javascript
[52:20]DOTA2-DPC中国联赛正赛 SAG vs XGBO3 第一场 3月5日
2021/03/11 DOTA
Python实现的简单发送邮件脚本分享
2014/11/07 Python
Python字符串匹配算法KMP实例
2015/07/18 Python
LRUCache的实现原理及利用python实现的方法
2017/11/21 Python
解决tensorflow模型参数保存和加载的问题
2018/07/26 Python
python traceback捕获并打印异常的方法
2018/08/31 Python
python如何保证输入键入数字的方法
2019/08/23 Python
纯css3实现鼠标经过图片显示描述的动画效果
2014/09/01 HTML / CSS
美国时尚配饰品牌:Dooney & Bourke
2017/11/14 全球购物
商务英语本科生的自我评价分享
2013/11/15 职场文书
业务代表的岗位职责
2013/11/16 职场文书
KTV的创业计划书范文
2014/02/02 职场文书
班级活动策划书
2014/02/06 职场文书
环保倡议书格式范文
2014/05/14 职场文书
庆国庆国旗下讲话稿2014
2014/09/21 职场文书
2015年大学迎新工作总结
2015/07/16 职场文书
运动会运动员赞词
2015/07/22 职场文书
微软团队与 NASA 科学家和惠普企业(HPE)的工程师合作
2022/04/21 数码科技