父组件和子组件相互传值

Posted cxscode

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了父组件和子组件相互传值相关的知识,希望对你有一定的参考价值。

父组件向子组件传值 props

父组件:

 标签

<child type="note" :defaultValue="mdl.title"></child>

  

子组件:

 标签 

<p>type</p>

 脚本

props: 
    type: null,
    defaultValue : null
,

   或者

props: [‘type‘, ‘defaultValue‘],

我一般默认设null(不初始值会报错),然后在beforeMount()方法做判断和赋值

beforeMount () 
    if (this.defaultValue) 
      this.setData(this.defaultValue)
    
,
methods: 
    setData (data) 
      this.fileList = data
    ,

注:如果父组件传进来的带下划线,传进来的数据是a-bc, vue转化成aBc, 在js 里面写aBc

 

子组件更新值给父组件 this.$emit

父组件:

 标签

<child v-on:change="showChildChange"></child>

  或者

<child @change="showChildChange"></child>

 脚本  

methods: 
    showChildChange (value) 
        console.log(‘value‘, value)
    

  

子组件:

this.$emit 子组件发射自定义事件sendiptVal 并携带要传递给父组件的值

脚本

methods: 
    handleChange ( data ) 
      this.$emit(‘change‘, data)
    ,
,

如果要传递给父组件很多值,这些值要作为参数依次列出 如 this.$emit(‘change‘, 1, 2); 

 

还有一种watch(监听)父组件数据的方法,可参考:https://www.jianshu.com/p/1b7e8a28d836

 

参考:

vue 中父子组件传值:props和$emit:https://www.cnblogs.com/rlann/p/7163045.html

vue—子组件修改父组件的值:https://blog.csdn.net/sinat_36422236/article/details/79403718

 

以上是关于父组件和子组件相互传值的主要内容,如果未能解决你的问题,请参考以下文章

react native 之子组件和父组件之间的通信

怎样在C#中实现父窗体向子窗体传值和子窗体向父窗体传值

vue 子父组件相互调用的方法 2018-11-09

vue中 的传值问题 父传子和子传父

Vue组件传值

Vue_(组件通讯)父组件向子组件传值