我有两个组成部分:父母和孩子。父级有一个cars
数组,子级应该被推入cars
数组。我的问题是我的Child组件将cars
变成了一个对象,而不是将一个对象推入cars
数组中。我的父母组件:
<template>
<child v-model="cars"></child>
<ul>
<li v-for="car in cars">
{{ car.model }}
</li>
</ul>
</template>
export default {
data: function() {
return {
cars: []
}
}
}
“我的孩子”组件:
<template>
<div>
<button type="button" @click="addCar()">Add Car</button>
</div>
</template>
export default {
methods: {
addCar() {
this.$emit("input", { model: "some car model" })
}
}
}
预期结果:
cars
得到更新并成为[{ model: "some car model"}, { model: "some car model"}, etc...]
实际结果:
cars
成为对象{model: "some car model"}
这是我的小提琴:
https://jsfiddle.net/t121ufk5/529/
我认为我在子组件上使用v-model
的方式有问题和/或我发出的方式不正确。有人可以帮忙吗?提前致谢!
答案 0 :(得分:3)
让我们讨论为什么您没有得到正确的结果。然后我们讨论解决该问题的其他方法。
首先,我们需要了解默认情况下v-model
在自定义组件上如何工作。
使用文本input
(包括email
,number
等类型)或textarea
时,v-model="varName"
等同于{{1 }}。这意味着在每次将对输入:value="varName" @input="e => varName = e.target.value"
的更新更新为输入的值之后,将输入的值设置为varName
。普通选择元素也将像这样,尽管多次选择会有所不同。
现在我们需要了解
v模型如何在组件上工作?
由于Vue不知道您的组件应该如何工作,或者如果它试图替代某种类型的输入,因此就varName
而言,它会将所有组件视为相同。实际上,它的工作方式与文本输入完全相同,只是在事件处理程序中,它不希望将事件对象传递给它,而是希望将值直接传递给它。所以...
v-model
…与…相同……
<my-custom-component v-model="myProperty" />
因此,当您应用此方法时。您必须收到<my-custom-component :value="myProperty" @input="val => myProperty = val" />
作为道具。并确保您的value
名称为$emit
。
现在您可以在这个阶段问我,您做错了什么?
好,看看类似的代码input
@input="val => myProperty = val"
产生新值时。此$emit
将更新您要更新的父级值。
这是您的代码newValue
。
您使用对象更新了父值。因此,您的this.$emit("input", { model: "some car model" })
已更新为Array
。
让我们解决所有问题。
父组件: `
Object
`
子组件:
<template>
<child v-model="cars"></child>
<ul>
<li v-for="car in cars">
{{ car.model }}
</li>
</ul>
</template>
export default {
data: function() {
return {
cars: []
}
}
}
您实际上可以用几种方法解决它。
第二种方法,
父母:
<template>
<div>
<button type="button" @click="addCar()">Add Car</button>
</div>
</template>
export default {
props: ['value']
methods: {
addCar() {
this.$emit("input", this.value.concat({model: "some car model"}))
}
}
}
孩子:
<template>
<child :cars="cars"></child>
<ul>
<li v-for="car in cars">
{{ car.model }}
</li>
</ul>
</template>
export default {
data: function() {
return {
cars: []
}
}
}
最后的方法:
父母:
<template>
<div>
<button type="button" @click="addCar">Add Car</button>
</div>
</template>
export default {
props: {
cars: {
type: Array,
default:[]
}
},
methods: {
addCar() {
this.cars.push({ model: "some car model" })
}
}
}
孩子:
<template>
<child @update="addCar"></child>
<ul>
<li v-for="car in cars">
{{ car.model }}
</li>
</ul>
</template>
export default {
data() {
return {
cars: []
}
}
},
methods: {
addCar() {
this.cars.push({ model: "some car model" })
}
}
}
答案 1 :(得分:0)
可以触发在props
在父级
<my-component :is-open.sync="isOpen" />
在我的组件中
this.$emit('update:isOpen', true)