vue中单向数据流中不允许在子组件修改父组件传过来的props值

Vue.js提倡单向数据流,不允许子组件直接修改父组件传入的props,以防止意外改变父组件状态。当需要类似双向绑定的效果时,可以使用.sync修饰符配合this.$emit('update:propName', newValue)通知父组件更新。子组件如果需要使用prop作为初始值或转换prop,应创建本地data属性或计算属性。注意,对象和数组类型的props修改会直接影响父组件。" 107151256,3039001,Flink配置详解:Linux环境下的完整安装与配置,"['大数据', 'Flink', 'Linux', 'Hadoop']
摘要由CSDN通过智能技术生成

**参考:https://blog.csdn.net/xueli_2017/article/details/90579048

vue报错: [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop’s value. Prop being mutated:

翻译:
避免直接改变一个组件中的prop值,因为每当父组件重新渲染时,该prop值都将被覆盖。应在组件中使用基于这个prop值的data或computed属性。

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

https://cn.vuejs.org/v2/guide/components-props.html#单向数据流

在有些情况下,我们可能需要对一个 prop 进行“双向绑定”。不幸的是,真正的双向绑定会带来维护上的问题。

取而代之的是,在父组件中对传递给子组件的prop使用.sync修饰符,子组件改变prop后,以 this.$emit(‘update: propName’, newvalue)的模式触发事件,告诉父组件我已经更改这个prop值了。
https://cn.vuejs.org/v2/guide/components-custom-events.html#sync-修饰符
在父组件中对传递给子组件的prop使用.sync修饰符:

props: {
   
    selectType: {
   
      type: Number,
      default: 2
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值