美文网首页
23-父给子传值

23-父给子传值

作者: 早起的鸟儿 | 来源:发表于2019-10-18 14:34 被阅读0次

一、父组件给子组件传值:
思路:在父组件绑定属性然后在子组件里通过props:["属性名"]接收值
父组件:

<template>
    <div>
        <Child :message="message"></Child>
    </div>
</template>
<script>
import child from '../common/Child.vue'
export default {
    name:"parent",
    components:{  //定义组件
        Child:Child
    },
    data(){
        return{
            message:'组件'
        }
    }
}
</script>

子组件:

<template>
    <div>
        <h1>{{message}}</h1>
    </div>
</template>
<script>
export default {
    name:"Child",
    props:["message"],
    data(){
        return{
        }
    },
}
</script>
单向数据流

所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。

额外的,每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你应该在一个子组件内部改变 prop。如果你这样做了,Vue 会在浏览器的控制台中发出警告,但是我们可以通过对象是引用类型传递的是地址,就可以改变props单项数据流。

举个例子🌰

父组件:

<template>
    <div>
        <child :message="obj"></child>
        {{obj.str}}
    </div>
</template>
<script>
import Child from '../common/Child.vue'
export default {
    name:"parent",
    components:{
        Child
    },
    data(){
        return{
            obj:{
                str:"父组件"
            }
        }
    }
}
</script>

子组件:

<template>
    <div>
        <h1 @click="run">{{message.str}}</h1>
    </div>
</template>
<script>
export default {
    name:"Child",
    props:["message"],
    data(){
        return{
        }
    },
    methods:{
        run(){
            this.message.str = "123"
        }
    }
}
</script>

这样一来,当我点击子组件里边的文字时候,子组件和父组件的值都会改变,也不会报错。

二、哪几种情况下子组件需要修改props值?怎么做?

  1. 这个 prop 用来传递一个初始值;这个子组件接下来希望将其作为一个本地的 prop 数据来使用。在这种情况下,最好定义一个本地的 data 属性并将这个 prop 用作其初始值:

    props: ['initialCounter'],
    data() {
      return {
        counter: this.initialCounter
      }
    }
    
  2. 这个 prop 以一种原始的值传入且需要进行转换。在这种情况下,最好使用这个 prop 的值来定义一个计算属性:

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

总结:父组件给子组件传值通过属性绑定,在子组件中通过props接受值,当更新父组件的值的时候,子组件也会自动更新。但是这个属于单项数据流,所以不应该在子组件修改,如果在子组件需要修改值,那可以在子组件通过在data中定义一个属性来保存props值。

如果直接修改父组件的值,浏览器会发出警告,当然我们也可以通过对象是引用类型的地址来修改,也不会发出警告。

相关文章

  • Vue_组件间传值

    1、父组件传值给子组件2、子组件传值给父组件 1、父组件传值给子组件 2、子组件传值给父组件

  • vue2.0 父子组件传值

    父组件传值给子组件 子组件 子组件通过 props 接收值 父组件 父组件通过标签属性传值 子组件传值给父组件 子...

  • react子组件、父组件相互传值

    子组件传图片路径imgUrl值给父组件,父组件传imgaddr值给子组件子组件: 父组件:

  • vue5

    1.父给子传值 属性 props:['属性'] 2.子给父传 用事件传 $emit 子给父传:

  • vue第六章

    1.父给子传值 属性 props:['属性'] 2.子给父传 用事件传 $emit 子给父传:

  • React专题4: 组件间通信

    父控件 传值 给子控件, 父控件可以将值 赋给子控件的一个属性(属性赋值)子控件 传值 给父控件, 需要父控件将自...

  • 【Vue3 从入门到实战 进阶式掌握完整知识体系】011-探索组

    2、组件间传值及传值校验 父组件给子组件传值 运行结果 父组件给子组件传动态参数 运行结果 子组件校验父组件的传参...

  • 2018-09-05

    组件传值问题 父组件给子组件传值应该使用props。子组件要给父组件传值,需要调用父组件传递的方法。props传值...

  • 08-父子组件间的通信:子组件给父组件传值

    一、子组件给父组件传值(1) 子组件给父组件传值(2) 二、父子通信混合使用

  • React 父子组件通信

    父子组件通信分为【父组件给子组件传值】、【父组件获取子组件的值】两类。 一.父组件给子组件传值3种方式 1.父组件...

网友评论

      本文标题:23-父给子传值

      本文链接:https://www.haomeiwen.com/subject/gjwcmctx.html