Vue 子组件与数据传递问题及注意事项


Posted in Javascript onJuly 11, 2019

在面对单个组件逻辑复杂需要拆分时,难免会遇到父子组件之间数据传递的问题。那么我们来了解一下在父子组件之间进行数据传递时需要遵循哪些约定,以及要注意哪些问题。

如何传递

父组件向子组件在进行传递时,使用的是 prop 特性进行传递。

约定

老规矩, 在使用前我们首先了解应该怎么使用,有哪些约束条件:

  • 子组件的 props 中定义要传递的变量名
  • 变量名同组件的命名规范
  • 父组件传值时,需要使用 短横线分隔命名
  • 使用 v-bind 进行传值

定义

首先在子组件中定义:

// Child.vue

export default {
  name: 'child'
  props: ['teamList']
}

这里使用了 驼峰命名 ,在传值时需注意要转换成 短横线分隔命名 。

我们定义了一个 teamList 的变量,此时我们就可以在这个组件中通过 this 使用这个变量了(同 data 中的数据)。

传值

在父组件中进行传值:

<template>
  <div>
    <child v-bind:teamList="teamList"></child>
  </div>
</template>

父组件中使用 v-bind 即可将数据传递下去了。

向子组件传递数据就是这么简单,本质上和 data 一样,只是这里单独使用 prop 特性将其区分开来。

需要注意的时:

通过 prop 特性传递下去的数组是 “单向”绑定的,父组件对数组的更新会影响到子组件。因此并不建议子组件对 prop 特性中的值进行修改

Js中在传递对象和数组时传递的时引用!因此:当子组件修改父组件传递下来的对象/数组时会影响到父组件中的状态

这个特性有利有弊,在某些情况下可以通过这种类似 hack 的方式来进行处理。

子组件反向传递

上面说到了,并不建议在子组件中修改 props 中的数据。那么当需要向父组件进行某种 反馈 时怎么办呢?

假设现在我们有一个登录弹出框的组件,通过子组件的方式调用了,当我们登录成功时该如何 通知 父组件做出相应的反应呢?

  1. 通过自定义事件,子组件调用 this.$emit('事件名', 参数)
  2. 使用 v-model 、组件中 model 选项与 input 事件模拟成 input 控件,对父组件中的值进行更新
  3. .sync 修饰符进行 “双向绑定”

这里只介绍第一种方式,因为后两种方式若羽也没用过几次 o(?□?)o

emit使用约定

  • 事件名的命名规范同组件
  • 父组件在绑定子组件上的自定义事件时,必须 完全匹配 事件名,这里不像组件与子组件中使用时是使用的 短横线分隔命名 ,而是 完全匹配 。

约定较少,主要注意使用时是和组件不同的,名称需要完全匹配。

emit使用

首先我们在子组件中定义事件,说是定义,不如说是调用。因为是子组件直接在某段逻辑中调用的 emit :

// child.vue

export default {
  methods: {
    submit() {
      this.$emit('submitForm', this.data)
    }
  }
}

这里我们定义了调用的自定义事件名称为 submitForm ,那么在父组件中使用:

<!-- parent.vue -->

<template>
  <div>
    <child v-on:submitForm="submit"></child>
  </div>
</template>
<script>
export default {
  methods: {
    submit(data) {
      // 处理逻辑
    }
  }
}
</script>

可以看到这里在使用时, v-on 绑定的事件名称是 submitForm 而不是 submit-form 。

这一点需要注意。

写在后面

以上所述是小编给大家介绍的Vue 子组件与数据传递问题及注意事项 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
JavaScript语法着色引擎(demo及打包文件下载)
Jun 13 Javascript
fix-ie5.js扩展在IE5下不能使用的几个方法
Aug 20 Javascript
javascript整除实现代码
Nov 23 Javascript
基于prototype扩展的JavaScript常用函数库
Nov 30 Javascript
微信+angularJS的SPA应用中用router进行页面跳转,jssdk校验失败问题解决
Sep 09 Javascript
漂亮实用的页面loading(加载)封装代码
Feb 03 Javascript
Vue报错:Uncaught TypeError: Cannot assign to read only property’exports‘ of object’#‘的解决方法
Jun 17 Javascript
layer弹出层全屏及关闭方法
Aug 17 Javascript
微信小程序非swiper组件实现的自定义伪3D轮播图效果示例
Dec 11 Javascript
jQuery/JS监听input输入框值变化实例
Oct 17 jQuery
Vue微信公众号网页分享的示例代码
May 28 Javascript
关于vue 结合原生js 解决echarts resize问题
Jul 26 Javascript
ES6的异步终极解决方案分享
Jul 11 #Javascript
微信小程序的开发范式BeautyWe.js入门详解
Jul 10 #Javascript
实现一个 Vue 吸顶锚点组件方法
Jul 10 #Javascript
vue webpack重写cookie路径的方法
Jul 10 #Javascript
vue登录页面cookie的使用及页面跳转代码
Jul 10 #Javascript
Laravel admin实现消息提醒、播放音频功能
Jul 10 #Javascript
微信小程序把百度地图坐标转换成腾讯地图坐标过程详解
Jul 10 #Javascript
You might like
Extjs优化(二)Form表单提交通用实现
2013/04/15 Javascript
基于JQuery 选择器使用说明介绍
2013/04/18 Javascript
js对象的复制继承实例
2015/01/10 Javascript
探究Javascript模板引擎mustache.js使用方法
2016/01/26 Javascript
ECMAScript6快速入手攻略
2016/07/18 Javascript
JavaScript判断数组是否存在key的简单实例
2016/08/03 Javascript
js放到head中失效的原因与解决方法
2017/03/07 Javascript
用JS实现简单的登录验证功能
2017/07/28 Javascript
Angular2开发环境搭建教程之VS Code
2017/12/15 Javascript
Vue.js通用应用框架-Nuxt.js的上手教程
2017/12/25 Javascript
JS实现键值对遍历json数组功能示例
2018/05/30 Javascript
vue.js多页面开发环境搭建过程
2019/04/24 Javascript
vue轻量级框架无法获取到vue对象解决方法
2019/05/12 Javascript
vue项目中使用AES实现密码加密解密(ECB和CBC两种模式)
2019/08/12 Javascript
js实现的订阅发布者模式简单示例
2020/03/14 Javascript
JavaScript定时器使用方法详解
2020/03/26 Javascript
Quasar Input:type=&quot;number&quot; 去掉上下小箭头 实现加减按钮样式功能
2020/04/09 Javascript
如何在postman中添加cookie信息步骤解析
2020/06/30 Javascript
python logging 日志轮转文件不删除问题的解决方法
2016/08/02 Python
python自动发邮件库yagmail的示例代码
2018/02/23 Python
python去掉空白行的多种实现代码
2018/03/19 Python
Python之文字转图片方法
2018/05/10 Python
python3解析库BeautifulSoup4的安装配置与基本用法
2018/06/26 Python
Python2实现的图片文本识别功能详解
2018/07/11 Python
利用Pycharm断点调试Python程序的方法
2018/11/29 Python
利用python Selenium实现自动登陆京东签到领金币功能
2019/10/31 Python
Pycharm远程连接服务器并实现代码同步上传更新功能
2020/02/25 Python
Python CategoricalDtype自定义排序实现原理解析
2020/09/11 Python
10种CSS3实现的loading动画,挑一个走吧?
2020/11/16 HTML / CSS
html5是什么_动力节点Java学院整理
2017/07/07 HTML / CSS
澳大利亚女装精品店:Alannah Hill
2020/07/29 全球购物
社区活动邀请函范文
2014/01/29 职场文书
宣传普通话标语
2014/06/27 职场文书
2015入党自荐书范文
2015/03/05 职场文书
2015学习委员工作总结范文
2015/04/03 职场文书
2015年银行个人工作总结
2015/05/14 职场文书