已知Vue中的 v-model 是 :value="value" @change="changeFunc" 的语法糖
官方文档: 计算属性默认只有 getter,不过在需要时你也可以提供一个 setter
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
</head>
<body>
<div id="el">
<my-son v-model="value"></my-son>
<span>{{value}}</span>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.js"></script>
<script>
new Vue({
el: "#el",
data() {
return {
value: "",
};
},
components: {
mySon: {
template: `<div><input v-model="instance" placeholder="请输入" /></div>`,
props: ["value"],
computed: {
instance: {
get() {
return this.value;
},
set(value) {
this.$emit("input", value);
},
},
},
},
},
});
</script>
</body>
</html>