【vue】Prop being mutated: “placement“

问题现象:

控制台错误信息: [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: “placement”
在这里插入图片描述
vue版本:element-ui@2.15.9 (npm list 即可查看版本)

原因分析:

高于2.15.6版本的element-ui在date-picker组件新增了一行直接修改placement的代码

    this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;

在这里插入图片描述

在这里插入图片描述

解决方法:

  1. 查看package.json文件中element-ui的版本号
    在这里插入图片描述
  2. 版本号是以^开头(表示安装2.0最高版本),先卸载,再重装element-ui,即可解决
    npm uninstall element-ui
    npm install element-ui@2.15.6
    
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 这个警告是因为在子组件中直接修改了父组件传递过来的 prop 值,而这个值会在父组件重新渲染时被覆盖。为了避免这种情况,应该在子组件中使用一个基于 prop 值的 data 或 computed 属性来代替直接修改 prop 值。在这个警告中,被修改的 prop 是 "placement"。 ### 回答2: 这条警告信息是针对 Vue 组件中的一个 prop(属性)——"placement" 的直接修改而发出的。在 Vue 组件中,props 是通过父组件向子组件传递数据的方式之一。不同于在组件的 data 选项中初始化的变量,在组件中定义的 props 是单向传递的,是父组件向子组件传递的数据源,子组件只能从 props 中读取数据,而不能直接修改。 在 Vue.js 中,如果一个子组件直接修改了 props 的值,那么 Vue 会发出这样的警告。因为直接修改 props 的值会导致子组件与父组件之间的数据失去同步,而且父组件在更新自己的数据时也可能会覆盖掉子组件直接修改的值,从而引发不可预测的问题。 解决这个问题的方法是:在子组件中定义一个与 "placement" prop 相关的 data 或 computed 属性,通过修改这个属性的值来实现与该 prop 相关的功能。这种方式可以保证子组件中定义的数据与父组件中传递过来的 props 始终保持同步,同时也不会影响父组件中的数据更新操作。 关于使用 data 或 computed 属性来响应 props 的变化的区别,一般来说,如果 prop 的值对应着一个组件内部需要响应的变化,那么可以使用 data 属性来定义一个与 prop 相关的变量。如果 prop 的值需要经过计算才能得出相应的结果,可以使用 computed 属性来定义一个计算属性,根据需要通过 prop 的值进行计算,得到最终的结果。无论使用哪种方式,都需要注意不要直接修改 prop 的值,避免引发不必要的问题。 ### 回答3: Vue在控制台输出“vue warn: 避免直接修改prop的值,因为当父组件重新渲染时,该值会被覆盖。应该使用基于prop值的data或computed属性。”错误信息提示,在一个组件中,一个prop被修改了,而且是直接在子组件中修改的,这样会导致子组件不能保证从父组件得到的prop的值与父组件的值一致,从而引发问题。 针对该问题,我们需要注意以下两点: 第一点,在子组件中不要直接修改传递进来的prop。我们需要了解Vue的响应式特性,如果我们直接修改了传递进来的prop,那么在父组件重新渲染时,该值将会被覆盖。Vue通过比较新值和旧值的操作来进行优化,如果新值和旧值相等,那么就不会执行组件更新操作。由于直接修改prop的值将导致组件和父组件的数据不一致,因此Vue框架会发出警告。 第二点,我们应该通过定义一个computed属性或者一个响应式的data属性来间接修改prop的值,保证子组件中的值与父组件中的值同步。由于Vue是响应式框架,我们可以定义一个computed属性或者响应式的data属性,通过该属性来间接修改prop的值,从而保证子组件中的值和父组件中的值一致。当我们修改了这个属性的值时,该操作不会对父组件的数据造成影响,同时也不会打破父组件和子组件之间的数据传递。 综上所述,我们需要在开发Vue组件时严格遵循Vue框架的响应式特性,不要直接修改传递进来的prop的值,而是应该通过定义一个computed属性或者响应式的data属性来间接修改prop的值,保证子组件中的值和父组件中的值同步,从而避免出现不必要的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值