项目中,我们经常会遇到自定义组件传值的问题,方法很多种,但是原理很简单,下述文档总结实际项目中使用的传值方式。

父组件传递给子组件某一值,子组件内会修改该值,然后父组件需要获取新值

​ 在 Vue 中,父子组件的关系可以总结为 prop 向下传递,事件向上传递。父组件通过 prop给子组件下发数据,子组件通过事件给父组件发送消息。

常规prop-event

父组件

<prop-event-value :address="address" @update="val => address = val" key="4"></prop-event-value> <script> import propEventValue from './components/prop-event-value.vue' export default { name: 'app', components: { propEventValue }, data() { return { address: '' } } } </script>

子组件

<template><div><p>prop-event</p> <label for="address">地址</label> <input type="text" id="address" v-model="tempAddress"> </div> </template> <script> export default { name: 'prop-event', props: ['address'], data() { return { tempAddress: this.address } }, watch: { tempAddress(newVal) { this.$emit('update', newVal) } } } </script>

需要注意:不要直接在子组件内操作父组件的内容

​ 组件实例的作用域是孤立的。每次父组件更新时,子组件的所有 prop 都会更新为最新值。这意味着不能 (也不应该) 在子组件的模板内直接引用父组件的数据。如果你这么做了,Vue 会在控制台给出警告。

export default {name: 'prop-event',props: ['address'],watch: {address(newVal) {this.$emit('update', newVal) } } }

如将上述代码替换子组件,内容会报错! 

修饰符.sync

父组件

<my-sync-value :address.sync="address" key="5"></my-sync-value> <script> import mySyncValue from './components/my-sync-value.vue' export default { name: 'app', components: { mySyncValue }, data() { return { address: '' } } } </script>

子组件

<template><div><p>my-sync</p> <label for="address">地址</label> <input type="text" id="address" v-model="tempAddress"> </div> </template> <script> export default { name: 'my-sync', props: ['address'], data() { return { tempAddress: this.address } }, watch: { tempAddress(newVal) { // 必须是这个update:address this.$emit('update:address', newVal) } } } </script>

prop-update:[prop]语法糖,与prop-event对比的优势:父组件无需监听事件@update="val => address = val",自动监听update:[prop]事件。

双向数据绑定v-model

所以要让组件的 v-model 生效,它应该 (从 2.2.0 起是可配置的):

  • 接受一个 value prop
  • 在有新的值时触发 input 事件并将新值作为参数

父组件

<my-vmodel-value v-model="address" key="6"></my-vmodel-value> <script> import myVmodelValue from './components/my-vmodel-value.vue' export default { name: 'app', components: { myVmodelValue }, data() { return { address: '' } } } </script>

子组件

<template><div><p>my-vmodel</p> <label for="address">姓名</label> <input type="text" id="address" v-model="tempAddress"> </div> </template> <script> export default { name: 'my-vmodel', props: ['value'], data() { return { tempAddress: this.value } }, watch: { tempAddress(newVal) { // 必须是input this.$emit('input', newVal) } } } </script> 

prop-input语法糖,父组件v-model默认监听input事件 
需要注意,这里必须触发input事件,当然也可以自定v-model属性值和事件,请参照自定义组件的v-model

vuex

通过store传值,这里后续单独讲述vuex。

单向数据流

​ 上述已经提及,在子组件内部改变 prop,Vue会在控制台给出告警。但经常开发周静,我们很容易忍不住修改prop中的数据,如:

  • Prop 作为初始值传入后,子组件想把它当作局部数据来用;
  • Prop 作为原始数据传入,由子组件处理成其它数据输出。

对这两种情况,正确的应对方式是: 
问题1:定义一个局部变量,并用 prop 的值初始化它:

props: ['initialCounter'],
data: function () {return { counter: this.initialCounter } }

问题2:定义一个计算属性,处理 prop 的值并返回:

props: ['size'],
computed: {normalizedSize: function () {return this.size.trim().toLowerCase() } }

特别需要注意:在 JavaScript 中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态。

vue-自定义组件传值相关推荐

  1. Vue自定义组件及组件传值

    vue自定义组件: 1.在src中components中,新建文件,后缀名为.vue组件(首字母建议大写)例如:Weekly.vue 2.Weekly.vue: 3.在app.vue中引用组件: js ...

  2. Vue自定义组件与Vue组件组件传值

    一.Vue自定义组件 组件是可复用的 Vue 实例,且带有一个名字.组件的出现是为了拆分 Vue 实例的代码量的,能够让我们以不同的组件,来划分不同的功能模块,将来我们需要什么样的功能,就可以去调用对 ...

  3. 如何运用Vue自定义组件以及组件的传值

    Vue自定义组件 引入组件 首先在项目内的components新建.vue文件. 创建完成之后搭建完整的框架.其实就是新建组件,在此之前,需要在VScode中引入一个插件(vue 2 snippets ...

  4. vue自定义组件是.vue还是html,Vue自定义组件的四种方式示例详解

    四种组件定义方式都存在以下共性(血泪史) 规则: 1.组件只能有一个根标签 2.记住两个词全局和局部 3.组件名称命名中'-小写字母'相当于大写英文字母(hello-com 相当于 helloCom) ...

  5. vue父子组件传值:详解父组件向子组件传值(props)

    vue父子组件传值:父组件向子组件传值用的是props 1.定义父组件 1)父组件想要向子组件传值时,那么需要在子组件引入的地方绑定一个属性,属性值就是要传的数据,并且要在父组件中引入子组件. 2)这 ...

  6. vue 自定义组件双向数据绑定

    文章目录 序 属性&事件传值双向绑定 v-model组件双向绑定 .sync修饰符双向绑定 总结 !!!这边文章记录的是 vue2 的概念,vue3 对双向绑定进行了改动,不要把一下代码放到 ...

  7. Vue自定义组件 Vue.component

    Vue.component Vue自定义组件(1) 如果有朋友对Vue基础还不够了解的可以先看下官方的教程 http://doc.vue-js.com/v2/guide/  这个是官方的网址,官方的教 ...

  8. Vue自定义组件并引入

    今天,bug菌为大家带来一期帝王级干货,有关于前端vue的组件教学,深入指引大家在vue中如何创建自定义的组件,并且在vue中引入你自定义的组件: 具有很好的教学价值,希望小伙伴们根据这篇文章可以有所 ...

  9. vue 自定义组件切换时刷新

    我们在使用vue自定义组件时,常常会遇到切换组件的操作,但是切换组件的时候,如果没有处理好,组件内容就不会刷新.如:标签页下放自定义组件,切换标签时,组件里面的内容不刷新,导致页面停留在上一次的操作. ...

  10. Vue父子组件传值----$emit子传父

    Vue父子组件传值是个比较经典的问题,在这里,咱们先谈一下,子组件给父组件传值. 这是一个子组件 <!-- 子组件1 --> <template><div class=& ...

最新文章

  1. MySql通用二进制版本在Linux(Ubuntu)下安装与开启服务
  2. 年末最大AI盛典!2020深度学习开发者峰会报名启动
  3. win定时关机_两种方法让你设置电脑定时关机
  4. EE JSP:Servlet的反向外套
  5. 【渝粤教育】21秋期末考试工程经济10202k2
  6. 034_nginx报错总结
  7. GlobalSign 团队与世界领先的认证机构(CAs)合作 共同加强网络安全
  8. 前端自适应----单位rem
  9. 也许,真的有2012
  10. iframe调用父页面方法_5.1 vue中子组件调用父组件的方法,务必理解自定义事件的重要性...
  11. 三星固态硬盘linux驱动,三星固态硬盘驱动NVMe Driver
  12. Windows/Ubuntu 使用小技巧记录
  13. html中table分页显示,html中table表格分页
  14. simulink积分器报错
  15. 蝶式套利(butterfly spread)
  16. 找回任务栏显示桌面图标及Win7如何显示快速启动栏
  17. intel 7260 wifi linux,TK1入门教程基础篇-安装intel7260无线网卡
  18. 笔记本html外接显示器,提升效率 笔记本外接显示器(Intel篇)
  19. MacOS搭建golang开发环境
  20. 影响工程项目进度的因素有哪些

热门文章

  1. 一个完整的DS1302时钟在STM32上的应用实例
  2. ISP、IAP、ICP的区别!
  3. servlet输出html
  4. python十:字典(dict)
  5. go微服务框架-gomicro试用
  6. Android Crash战斗日记(一、原理篇)
  7. vue中引入第三方字体图标库iconfont,及iconfont引入彩色图标
  8. 服务器双网卡冗余备份技术的实现
  9. 我对软件行业及大数据的理解
  10. 开始写博客,毕业一年的收获