间歇性笔记--Vue组件间通信传值的各种方式

栏目: JavaScript · 发布时间: 5年前

内容简介:一般情况下,组件间的通信传值分为三种情况:可以在子组件中再通过比如可以实现

一般情况下,组件间的通信传值分为三种情况:

  1. 父组件向子组件(跨级)通信传值;
  2. 子组件向父组件(跨级)通信传值;
  3. 兄弟组件间通信传值;

父组件向子组件(跨级)通信传值

  • 使用prop传值,子组件使用 props 接受数据

    parent.vue
        //部分代码省略---
        <child 
            :prop='data'>
        </child>
    
        child.vue
        props:['data'],
    复制代码

    使用场景:

    对子组件进行传值,不会对子组件进行操作;

    注意:

    1. 当绑定静态数据时,最好也使用 v-bind ,不然Vue会全部当成字符串处理(字符串传递除外);
    2. 可以使用 v-bind='propObj' 的方式, propObj 是一个有属性的对象;
    3. 可以使用 v-bind='$props' 的方式,将父组件的 props 传值给子组件;
    4. 单向数据流,不允许在子组件中修改prop;
    5. 当希望prop在子组件可以当做本地data使用时,可以在data中复制 localData=this.data 。但是若prop为数组或者对象时,需使用深拷贝;
    6. 当希望在子组件对prop进行转换时,可以使用计算属性转换。但是若prop为数组或者对象时,需使用深拷贝;
      computed:{
              myDataTrim(){
                  return this.myData.trim();
              }
          }
      复制代码

    7.子组件中,style/class不允许接收;

  • 插槽

    可以通过插槽的方式,将父组件的内容传递到子组件,可以在子组件中设置默认值。

    parent.vue
        //部分代码省略---
        <child>
            hello
        </child>
    
        child.vue
        <div>
            <slot>
                默认值
            </slot>
        </div>
        //渲染结果:<div>hello</div>
    复制代码

    使用场景:

    传递给子组件,在子组件特定的位置渲染展示出来。传递的内容甚至可以为DOM元素、组件等。

    注意:

    1. 使用具名插槽可以指定父组件内容传递的位置;
      parent.vue
          //部分代码省略---
          <child>
              <template v-slot:slotName>
                  hello
              </template>
              //默认可以使用两种方式
              <template v-slot:default>
                  world
              </template>
              //or
              world
          </child>
      
          child.vue
          <div>
              <slot name='slotName'>
                  默认值1
              </slot>
              <div>
                  <slot>
                      默认值2
                  </slot>
              </div>
          </div>
      复制代码
    2. v-slot 一般写在 template 中;
    3. 缩写。 v-slot --> # ,特殊情况:默认插槽 #default ;
  • 父组件获取子组件实例(ref)

    在父组件中调用子组件时,设置 ref 属性,然后就可以通过 this.$refs[设置的值] 获取子组件的实例。

    parent.vue
        //部分代码省略---
        <child ref='childRef'>
        </child>
        //methods
        getChildData(){
            let data=this.$refs.childRef.data;
        }
    复制代码

    使用场景:

    当父组件想获取子组件的数据、方法时,可以通过这种方式进行获取数据、调用方法;

    注意:

    1. ref 设置在DOM元素上时,获取的是DOM元素;
    2. $refs 是一个对象,收集所有设置过 ref 的DOM元素或组件实例;
  • 非prop特性(

    attrs`对象中;

    使用场景:

    v-bind:$attrs
    v-bind:$attrs
    inheritAttrs:false
    
  • children[0].$children`跨级获取组件的实例;

    使用场景:

    1. 获取子组件的实例;
    2. 当组件层级不是很深时,可以通过这种方式跨级获取组件实例; 注意:
    3. 不适应组件层级较深的情况;

子组件向父组件(跨级)通信传值

  • $emit( 自定义事件名[,...param] )
    父组件绑定自定义组件,子组件中调用; 传递参数可以为零个或者多个;
    parent.vue
        //部分代码省略---
        <child
            @event1='handMethod()'>
        </child>
    
        child.vue
        methods:{
            setparent(){
                this.$emit('handMethod');
            }
        }
    复制代码
    使用场景:
    一般情况下,子组件调用父组件方法的方法;
  • 插槽prop
    在子组件中的slot上 v-bind 进行绑定,这样就可以通过 v-slot:slotName:props 的方法接收数据了,所有的插槽prop都接收在一个对象中;
    parent.vue
        //部分代码省略---
        <child>
            <template v-slot:slot1='data'>
                data.data
            </template>
        </child>
    
        child.vue
        <slot name ='slot1' :data='data'></slot>
    复制代码
    使用场景:
    当组件内部使用了循环,但是又想让不同的数据有不同的展现方式时使用;
  • 组件上使用v-model
    实现数据的"双向绑定";
    在父组件使用 v-model 绑定需要进行"双向绑定"的数据,在子组件可以通过 model:{} 进行设置 v-model 绑定的prop和事件名,然后可以在需要调用的地方调用;
    parent.vue
        //部分代码省略---
        <child v-model='data'>
        </child>
    
        child.vue
        <div>
            <input 
                type='text'
                :value='data'
                @input="$emit('customEvent', $event.target.value)">
        </div>
        export default {
            model:{
                prop:'data',
                event:'customEvent',
            },
            props:[data]
        }
    复制代码
    使用场景:
    一般在需要父子组件的数据需要进行"双向绑定"的情况下,进行使用;
    注意:
    1. 这是一个语法糖,并不是真正意义上的双向绑定,在子组件中,让父组件绑定一个prop以及一个自定义事件;
    //前面的例子
        <child v-model='data'>
        </child>
        or 
        <child 
            :data='data'
            @customEvent='data=$event'
            >
        </child>
    复制代码
  • .sync---也是语法糖
    当子组件向修改一个prop时,可以通过修改父组件的数据,从而达到修改的目的;
    parent.vue
        //部分代码省略---
        <child :title.sync='title'>
        </child>
    
        child.vue
        this.$emit('unpdate:title',newData);
    复制代码
    使用场景:
    子组件想修改prop的值时;
    注意:
    1. 这也是一个语法糖。让父组件绑定一个prop以及一个自定义事件---update:[prop的名字];
    parent.vue
        //部分代码省略---
        <child 
            :title='title'
            @update:title='title=$event'>
        </child>
    复制代码
  • listeners"`,这样可以跨级调用祖先的方法;
    使用场景:
    1. 可以在子组件中对父组件的方法进行调用;
    2. 可以达到跨级通信的功能;
  • parent[0].$parent`跨级获取组件的实例;
    使用场景:
    1. 获取父组件的实例;
    2. 当组件层级不是很深时,可以通过这种方式跨级获取组件实例; 注意:
    3. 不适应组件层级较深的情况;

$attrs$listeners

可以在子组件中再通过 v-bind:$attrs 以及 v-on="$listeners" 的方式进行跨级的通信传值;

比如可以实现 .syncv-model 的功能(需要最初传入的组件配合);

兄弟组件以及跨多级组件间传值

  1. vuex 使用的不多,而且相关的内容挺多的。等有空详细看看再总结一下。官方文档
  2. eventBus 建一个空的Vue实例作为中央事件总线; 进行将其定义在全局;
    let bus = new Vue();
    //一个组件中绑定
    bus.$on('evnet1',()=>{
    
    });
    组件销毁前
    beforeDestroy(){
        bus.$off('evnet1');
    }
    //另外一个组件中调用
    bus.$emit('evnet1'[,...param]);
    复制代码
  3. 数据存储在浏览器;---骚操作
  4. 通过路由传值; 在created钩子函数中,获取 $route 的值,进行相应的操作。

后记

对一些常用的组件间通信传值方法的使用与场景的理解,理解的比较粗略。后续可能会对Vuex以及 provide/inject 等方法进行一些学习---看情况而定。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Linux设备驱动程序

Linux设备驱动程序

科波特 / 魏永明、耿岳、钟书毅 / 中国电力出版社 / 2006-1-1 / 69.00元

本书是经典著作《Linux设备驱动程序》的第三版。如果您希望在Linux操作系统上支持计算机外部设备,或者在Linux上运行新的硬件,或者只是希望一般性地了解Linux内核的编程,就一定要阅读本书。本书描述了如何针对各种设备编写驱动程序,而在过去,这些内容仅仅以口头形式交流,或者零星出现在神秘的代码注释中。 本书的作者均是Linux社区的领导者。Jonathan Corbet虽不是专职的内核......一起来看看 《Linux设备驱动程序》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换