首页 > 其他 > 详细

Vue2 props引用传递和值传递响应式变化

时间:2021-06-03 00:56:55      阅读:32      评论:0      收藏:0      [点我收藏+]

值传递

父组件:

<template>
  <div>
    <h1>Parent</h1>
    <button @click="amount++">点击 amount++</button>
    <p>{{amount}}</p>
    <Child :data="amount"></Child>
  </div>
</template>

<script>
import Child from ‘./Child‘
export default {
  components: { Child },
  data () {
    return {
      amount: 10
    }
  }
}
</script>

子组件data接没有响应式,props改变子组件接受值不会改变:

export default {
  props: [‘data‘],
  data () {
    return {
      childValue: this.data
    }
  }
}

用计算属性接收有响应式:

export default {
  props: [‘data‘],
  computed: {
    computedChildValue () {
      return this.data
    }
  }
}

改变子组件中的值不会对父组件产生影响

引用传递

父组件

<template>
  <div>
    <h1>Parent</h1>
    <button @click="person.name=‘李四‘">点击改名</button>
    <p>{{person.name}}</p>
    <Child :data="person"></Child>
  </div>
</template>

<script>
import Child from ‘./Child‘
export default {
  components: { Child },
  data () {
    return {
      person: {
        name: ‘张三‘,
        age: 18
      }
    }
  }
}
</script>

子组件:

<template>
  <div>
    <h1>Child</h1>
    <p>data接收:{{childValue.name}}</p>
    <p>computed接收:{{computedChildValue.name}}</p>
    <button @click="childValue.name=‘王五‘">改名王五</button>
    <button @click="computedChildValue.name=‘赵六‘">改名赵六</button>
  </div>
</template>

<script>
export default {
  props: [‘data‘],
  data () {
    return {
      childValue: this.data
    }
  },
  computed: {
    computedChildValue () {
      return this.data
    }
  }
}
</script>

引用传递,子组件的data和computed都有响应式变化,且在子组件更改数据后,父组件也会发生改变

Vue2 props引用传递和值传递响应式变化

原文:https://www.cnblogs.com/simdot/p/14843213.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!