В моем случае у меня есть массив data
с несколькими объектами.
data() {
return {
selected: 0,
presetData: [true, true, true],
data: [
{
name: "name 1"
},
{
name: "name 2"
}
]
};
},
затем я хочу вставить каждый объект в data
, как показано ниже
setNewData() {
this.data.forEach((o, i) => {
this.$set(this.data[i], "time", this.presetData);
});
},
теперь мой с presetData
вставленным в data
будет выглядеть так
data: [
{
name: "name 1",
time: [true, true, true]
},
{
name: "name 2",
time: [true, true, true]
}
]
и я хочу изменить отдельное свойство time
каждого объекта, которое я использую примерно так:
$set(item.time,selected,true)
Моя проблема
моя проблема в том, что это изменит свойство time
обоих объектов. Как мне сначала правильно нажать/установить presetData
в data
, ниже весь мой код, извините, я очень новичок в программировании, вот ссылка на jsfiddle
new Vue({
el: "#app",
data() {
return {
selected: 0,
presetData: [true, true, true],
data: [
{
name: "name 1",
},
{
name: "name 2",
}
]
};
},
methods: {
setNewData() {
this.data.forEach((o, i) => {
this.$set(this.data[i], "time", this.presetData);
});
},
}
})
<div id="app">
<button @click="setNewData">Set Data</button>
<br>
<br>
<select v-model="selected">
<option>0</option>
<option>1</option>
<option>2</option>
</select>
<div v-for="item in data" :key="item.id">
<p>{{item.name}}</p>
<p>{{item.time}}</p>
<button @click="$set(item.time,selected,true)">Change True</button>
<button @click="$set(item.time,selected,false)">Change False</button>
</div>