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 相关文章推荐
JS弹出对话框返回值代码(asp.net后台)
Dec 28 Javascript
javascript数组快速打乱重排的方法
Jan 02 Javascript
jquery sortable的拖动方法示例详解
Jan 16 Javascript
$.each与$().each的区别示例介绍
Mar 20 Javascript
Jquery判断radio、selelct、checkbox是否选中及获取选中值方法总结
Apr 15 Javascript
jQuery动态背景图片效果实现方法
Jul 03 Javascript
详解js产生对象的3种基本方式(工厂模式,构造函数模式,原型模式)
Jan 09 Javascript
JS中常用的消息框总结
Feb 24 Javascript
react router4+redux实现路由权限控制的方法
May 03 Javascript
Vue学习之组件用法实例详解
Jan 06 Javascript
国内常用的js类库大全(CDN公共库)
Jun 24 Javascript
解决vue props传Array/Object类型值,子组件报错的情况
Nov 07 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出错界面
2006/10/09 PHP
详解:――如何将图片储存在数据库里
2006/12/05 PHP
php中如何防止表单的重复提交
2013/08/02 PHP
基于PHP给大家讲解防刷票的一些技巧
2015/11/18 PHP
php实现购物车功能(上)
2020/07/23 PHP
jquery简单体验
2007/01/10 Javascript
通过JQuery实现win8一样酷炫的动态磁贴效果(示例代码)
2013/07/13 Javascript
JavaScript数据绑定实现一个简单的 MVVM 库
2016/04/08 Javascript
手机图片预览插件photoswipe.js使用总结
2016/08/25 Javascript
使用bootstrap实现多窗口和拖动效果
2016/09/22 Javascript
node.js路径处理方法以及绝对路径详解
2021/03/04 Javascript
jQuery ajax的功能实现方法详解
2017/01/06 Javascript
拖动时防止选中
2017/02/03 Javascript
AngularJS实现页面跳转后自动弹出对话框实例代码
2017/08/02 Javascript
Javascript中JSON数据分组优化实践及JS操作JSON总结
2017/12/22 Javascript
Python读取mp3中ID3信息的方法
2015/03/05 Python
关于Django显示时间你应该知道的一些问题
2017/12/25 Python
Python爬虫学习之翻译小程序
2019/07/30 Python
Python中Subprocess的不同函数解析
2019/12/10 Python
Python函数必须先定义,后调用说明(函数调用函数例外)
2020/06/02 Python
Python绘制组合图的示例
2020/09/18 Python
如何使用Pytorch搭建模型
2020/10/26 Python
用python批量下载apk
2020/12/29 Python
python 实现的车牌识别项目
2021/01/25 Python
戴尔美国官方折扣店:Dell Outlet
2018/02/13 全球购物
bonprix荷兰网上商店:便宜的服装、鞋子和家居用品
2020/07/04 全球购物
几道PHP的面试题
2012/05/19 面试题
企业宣传策划方案
2014/05/29 职场文书
庆六一宣传标语
2014/10/08 职场文书
群众路线教育实践活动调研报告
2014/11/03 职场文书
作文评语怎么写
2014/12/25 职场文书
小学生思想品德评语
2014/12/31 职场文书
最美劳动诗,致敬所有的劳动者!
2019/07/12 职场文书
Python基础之赋值,浅拷贝,深拷贝的区别
2021/04/30 Python
在Python 中将类对象序列化为JSON
2022/04/06 Python
Python通过loop.run_in_executor执行同步代码 同步变为异步
2022/04/11 Python