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代码
Dec 04 Javascript
JavaScript操作Oracle数据库示例
Mar 06 Javascript
js实现兼容性好的微软官网导航下拉菜单效果
Sep 07 Javascript
js控件Kindeditor实现图片自动上传功能
Jul 20 Javascript
javascript匀速动画和缓冲动画详解
Oct 20 Javascript
Angular使用$http.jsonp发送跨站请求的方法
Mar 16 Javascript
Vue.js学习笔记之常用模板语法详解
Jul 25 Javascript
vue打包使用Nginx代理解决跨域问题
Aug 27 Javascript
vue集成百度UEditor富文本编辑器使用教程
Sep 21 Javascript
ES6 fetch函数与后台交互实现
Nov 14 Javascript
element-ui多文件上传的实现示例
Apr 10 Javascript
element中table高度自适应的实现
Oct 21 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
异世界新番又来了,同样是从零开始,男主的年龄降到5岁
2020/04/09 日漫
php模拟ping命令(php exec函数的使用方法)
2013/10/25 PHP
php使用curl抓取qq空间的访客信息示例
2014/02/28 PHP
Laravel中正确地返回HTTP状态码方法示例
2019/09/10 PHP
Javascript数组的排序 sort()方法和reverse()方法
2012/06/04 Javascript
jquery 触发a链接点击事件解决方案
2013/05/02 Javascript
JavaScript中的关键字&quot;VAR&quot;使用详解 分享
2013/07/31 Javascript
javascript读取xml实现javascript分页
2013/12/13 Javascript
JavaScript中的Math.LOG2E属性使用详解
2015/06/14 Javascript
简介JavaScript中Math.cos()余弦方法的使用
2015/06/15 Javascript
浅谈JavaScript对象与继承
2016/07/10 Javascript
jQuery使用$获取对象后检查该对象是否存在的实现方法
2016/09/04 Javascript
AngularJS实现单独作用域内的数据操作
2016/09/05 Javascript
JavaScript实现设置默认日期范围为最近40天的方法分析
2017/07/12 Javascript
React+react-dropzone+node.js实现图片上传的示例代码
2017/08/23 Javascript
浅谈mint-ui 填坑之路
2017/11/06 Javascript
vue 搭建后台系统模块化开发详解
2019/05/01 Javascript
JS正则表达式封装与使用操作示例
2019/05/15 Javascript
基于ssm框架实现layui分页效果
2019/07/27 Javascript
原生js实现下拉框选择组件
2021/01/20 Javascript
python 文件操作api(文件操作函数)
2016/08/28 Python
python中字符串类型json操作的注意事项
2017/05/02 Python
Python3实现计算两个数组的交集算法示例
2019/04/03 Python
Python数据可视化实现正态分布(高斯分布)
2019/08/21 Python
linux下python中文乱码解决方案详解
2019/08/28 Python
国外最大的眼镜网站:Coastal
2017/08/09 全球购物
洛杉矶健身中心女性专用运动服饰品牌:Marika
2018/05/09 全球购物
现金会计岗位职责
2013/12/05 职场文书
宿舍使用违章电器检讨书
2014/01/12 职场文书
文秘应聘自荐书范文
2014/02/18 职场文书
大学学生会竞选演讲稿
2014/04/25 职场文书
任命书范本大全
2014/06/06 职场文书
离职员工给领导和同事的感谢信
2015/11/03 职场文书
写作技巧:如何撰写一份优秀的营销策划书
2019/08/13 职场文书
Java基础之详解HashSet的使用方法
2021/06/30 Java/Android
Python必备技巧之函数的使用详解
2022/04/04 Python