Vue中的Props(不可变状态)
程序员文章站
2022-06-02 10:23:30
组件接受的选项大部分与vue实例一样,而选项props是组件中非常重要的一个选项。在 vue 中,父子组件的关系可以总结为 props down, events up。父组...
组件接受的选项大部分与vue实例一样,而选项props是组件中非常重要的一个选项。在 vue 中,父子组件的关系可以总结为 props down, events up。父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送消息。接下来通过本文给大家介绍vue中props,一起看看吧!
单向数据流
所有的 prop 都使得其父子 prop 之间形成了一个单向下行绑定:父级 prop 的更新会向下流动到子组件中,但是反过来则不行。这样会防止从子组件意外改变父级组件的状态,从而导致你的应用的数据流向难以理解。
额外的,每次父级组件发生更新时,子组件中所有的 prop 都将会刷新为最新的值。这意味着你不应该在一个子组件内部改变 prop。如果你这样做了,vue 会在浏览器的控制台中发出警告。
问题
下面简要说一下上面发生的警告现象,或许大多数人都遇到过.
使用场景
父组件
<backlogmodal :ismodalopen="ismodalopen" @closemodal="handleclosemodal"> </backlogmodal>
- backlogmodal为一个弹窗组件,通过ismodalopen决定弹窗的开闭状态
- 传入的ismodalopen是父组件的一个变量,类型为boolean
- closemodal监听子组件派发的自定义事件closemodal
子组件
// 使用了typescript export default class backlogmodal extends vue { @prop() private ismodalopen: boolean; private handleconfirm(): void { this.$message.info('clicked ok'); this.$emit('closemodal'); } private handleclose(): void { this.$message.info('clicked cancal'); this.$emit('closemodal'); } }
- 通过@prop()注解获取父组件传递过来的ismodalopen属性
- 页面 通过v-model与属性ismodalopen进行绑定
- 由于弹窗组件在关闭时会自动设置ismodalopen的值为false,这里直接修改的就是父组件传入的ismodalopen属性,由于props属性是单向数据流,具有不可变状态,这是页面就会抛出警告
解决问题
export default class backlogmodal extends vue { private isopen: boolean = false; @prop() private ismodalopen: boolean; @watch('ismodalopen') private watchmodalopen(newval: boolean, oldval: boolean) { console.log(newval, oldval); if (newval !== oldval) { this.isopen = newval; } } private handleconfirm(): void { this.$message.info('clicked ok'); this.$emit('closemodal'); } private handleclose(): void { this.$message.info('clicked cancal'); this.$emit('closemodal'); } }
- 定义一个子组件私有变量isopen与页面弹窗就行绑定
- 使用@watch('ismodalopen')监听父组件传入的ismodalopen属性,一旦值发生改变,便更新本地变量isopen,确保弹窗的正常的打开与关闭
以上所述是小编给大家介绍的vue中的props(不可变状态),希望对大家有所帮助
上一篇: 男女恋爱中的搞笑词句
下一篇: 浅谈vue项目打包优化策略