我正在做一个进入Vue js的小项目。它应该是一个习惯追踪器。我目前有一个bug,如果你重新加载页面并添加新的习惯,我应该改变背景的功能就不能正常工作了。
here it shows the bug,下面是我的数组的外观:
0
:
{id: 0, title: "1", ready: false}
1
:
{id: 1, title: "123", ready: false}
2
:
{id: 2, title: "123", ready: false}
3
:
{id: 0, title: "123", ready: true}
我知道它为什么不工作了,因为我正在使用计数器来分配id,当重新加载时它会重置为0。
<div class="q-pa-md" v-for="(habit, index) in habits" :key="habit.id">
<q-card class="my-card" :id="habit.id" ref="card">
<q-card-section>
<q-checkbox
id="checkbox"
v-model="habit.ready"
@click="changeToTransparent(habit)"
>
</q-checkbox>
{{ habit.title }}
<q-btn-dropdown flat class="more" icon="more_horiz">
<q-list>
<q-item clickable v-close-popup @click="deletehabit(index)">
<q-item-section>
<q-item-label>Delete</q-item-label>
</q-item-section>
</q-item>
<q-item clickable v-close-popup @click="edithabitbutton(index)">
<q-item-section>
<q-item-label>Edit</q-item-label>
</q-item-section>
</q-item>
</q-list>
</q-btn-dropdown>
</q-card-section>
</q-card>
<div>
let counter = 0;
const habits = ref([]);
const addHabit = () => {
habits.value.push({ id: counter++, title: habittitle.value, ready: false });
savetolocalstorage();
habittitle.value = "";
};
const changeToTransparent = (habit) => {
if(document.getElementById(habit.id) != null) {
if (habit.ready) {
document.getElementById(habit.id).style.backgroundColor =
"rgba(170,193,200,0.25)";
savetolocalstorage();
} else {
document.getElementById(habit.id).style.backgroundColor = "";
savetolocalstorage();
}
}
}
你知道我该怎么补救吗?
2条答案
按热度按时间mklgxw1f1#
你需要加载你的localStorage并设置计数器值的长度。我在这里做了一个工作示例。我还改进了你的代码,使之更符合Vue的概念。正如@Rahul Purohit指出的,你需要在保存时
JSON.stringify
结果,在加载时JSON.parse
结果。yqhsw0fo2#
根据给定的上下文,我相信您没有使用任何后端,而是将所有条目保存在本地存储中。
如果是这种情况,您必须将数据存储在LS的某个数组中,例如
habits: []
在这里,您可以添加一个生命周期方法,而不是将计数器初始化为0。