Scenario Today, I encountered a strange problem when using [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: "value" This warning is caused by a custom component Vue.component("RxSelect", { model: { prop: "value", event: "change", }, props: { value: [Number, String], map: Map, }, template: ` <select v-model="value" @change="$emit('change', value)" > <option v-for="[k,v] in map" :value="k" :key="k" >{{v}}</option> </select> `, }); The code we are using seems to be fine? <main id="app"> The currently selected gender is: {{map.get(sex)}} <div> <rx-select :map="map" v-model="sex" /> </div> </main> JavaScript code new Vue({ el: "#app", data: { map: new Map().set(1, "Confidential").set(2, "Male").set(3, "Female"), sex: "", }, }); After testing, the program itself runs normally, there is no problem with the value transfer between parent and child components, and the two-way data binding does take effect, but the browser keeps reporting an error. Try to solveWe found a way
Vue.component("RxSelect", { model: { prop: "value", event: "change", }, props: { value: [Number, String], map: Map, }, data() { return { innerValue: this.value, }; }, watch: value(val) { this.innerValue = val; }, innerValue(val) { this.$emit("change", val); }, }, template: ` <select v-model="innerValue"> <option v-for="[k,v] in map" :value="k" :key="k" >{{v}}</option> </select> `, }); The usage code is exactly the same, but the code of the component solve A more elegant way is to use Vue.component("RxSelect", { model: { prop: "value", event: "change", }, props: { value: [Number, String], map: Map, }, computed: { innerValue: { get() { return this.value; }, set(val) { this.$emit("change", val); }, }, }, template: ` <select v-model="innerValue"> <option v-for="[k,v] in map" :value="k" :key="k" >{{v}}</option> </select> `, }); The above is the details of the problems and solutions encountered when Vue uses v-model to two-way bind the values of parent and child components. For more information about Vue using v-model to two-way bind the values of parent and child components, please pay attention to other related articles on 123WORDPRESS.COM! You may also be interested in:
|
>>: Detailed explanation of three ways to configure Nginx virtual hosts (based on ports)
Table of contents Preface advantage: shortcoming:...
This article describes how to export and import ....
This tutorial shares the installation and configu...
Table of contents 1 What is container cloud? 2 In...
1. Go to the official website: D:\mysql-5.7.21-wi...
1. Block-level element: refers to the ability to e...
During the development activity, I encountered a ...
The complete steps of Centos7 bridge network conf...
Recently, many students have asked me about web p...
Similar structures: Copy code The code is as foll...
<br />Adding pictures reasonably can make a ...
Install zip decompression function under Linux Th...
Table of contents UI Design Echarts example effec...
Comments and messages were originally a great way...
Preface I have seen many articles about the leftm...