uniapp不能直接修改props的数据原理浅析

uniapp不能直接修改props的数据

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: "expectDeliveryAt"

避免直接修改prop,因为每当父组件重新渲染时,该值都会被覆盖。相反,请根据data的值使用数据或计算属性。

产生原因:

在 Vue.js 中,一般不推荐在子组件中直接修改 props。这是由于 Vue 的响应式原理决定的。当你将一个对象作为 prop 传递给子组件,并在子组件中修改这个对象的属性,父组件并不能感知到这个修改。这是因为 Vue 只会关注对象属性的 getter 和 setter,当你在子组件中直接修改对象的属性,getter 和 setter 并没有触发,所以 Vue 无法感知到这个修改。

解决方法:

  • v-model 指令或 .sync 修饰符
  • 将修改属性的方法通过 v-bind 传给子组件调用,子组件直接按方法使用即可
  • 将修改属性的方法通过 v-on 传递给子组件调用,使用 $emit() 实现回调修改
  • 或者使用 this.$parent 去修改

实例:

props: ['params'],
  watch: {
  'params.approveStatus': function(newVal, oldVal) {
    this.$emit('update:params', { approveStatus: newVal });
  }
}

<child-component :params="params" @update:params="updateParams"></child-component>

methods: {
  updateParams(newParams) {
    this.params = newParams;
  }
}
相关推荐
纳尼亚awsl36 分钟前
处理元素卡在视野边界,滚动到视野内
前端·javascript·vue.js
永远不会太晚41 分钟前
JavaScript的diff库详解(示例:vue项目实现两段字符串比对标黄功能)
前端·javascript·vue.js
永远不会太晚5 小时前
前端vue+el-input实现输入框中文字高亮标红效果(学习自掘金博主文章)
前端·vue.js·学习
前端Mu偶人5 小时前
nodejs结合七牛云上传文件
前端·javascript·vue.js
KLW756 小时前
vant 地址记录
前端·javascript·vue.js
Zuojiangtao6 小时前
从@vue/cli项目迁移到Rsbuild
vue.js·webpack
_xaboy9 小时前
开源表单设计器form-create-designer如何保存设计器的规则和回显
vue.js·低代码·开源·动态表单·formcreate·低代码表单
火云牌神10 小时前
基于OAuth2.0和JWT规范实现安全易用的用户认证
vue.js·安全·fastapi
lmy_loveF10 小时前
vue v-for 数据增加页面不刷新
前端·javascript·vue.js
ai产品老杨10 小时前
基于服务器部署的综合视频安防系统的智慧快消开源了。
vue.js·人工智能·安全·开源·音视频