// 编辑数据 function editData(title, type) { const data = questionsData.find(q => q.title === title && q.type === type); title.value = data.title; type.value = data.type; options[0].value = data.options.A; options[1].value = data.options.B; options[2].value = data.options.C; options[3].value = data.options.D; answer.value = data.answer; score.value = data.score; } // 删除数据 function deleteData(title, type) { questionsData = questionsData.filter(q => !(q.title === title && q.type === type)); localStorage.setItem('questionsData', JSON.stringify(questionsData)); showData(); } // 选择类型 function selectType() { if (type.value === 'fill') { A.value = ''; B.value = ''; C.value = ''; D.value = ''; A.disabled = true; B.disabled = true; C.disabled = true; D.disabled = true; } else { A.disabled = false; B.disabled = false; C.disabled = false; D.disabled = false; } } // 显示数据 showData(); // 编辑和删除数据 const tbody = document.getElementById('tbody'); tbody.addEventListener('click', e => { const target = e.target; if (target.classList.contains('edit')) { editData(target.dataset.title, target.dataset.type); } else if (target.classList.contains('delete')) { const isConfirmed = confirm('确认删除此题目吗?'); if (isConfirmed) { deleteData(target.dataset.title, target.dataset.type); } } });为什么当我编辑完成 点击保存时不会实时更新并显示在页面上 且localstorage中也没有更新
时间: 2024-03-18 19:42:03 浏览: 139
Node.js-简单的nodejs爬虫
这可能是因为你没有在保存数据时更新 questionsData 数组中对应的数据。在 editData 函数中,你只是更新了表单中的值,但没有将更新后的值写回 questionsData 数组中。你需要在保存数据时将表单中的值写回 questionsData 数组中,并重新写入 localStorage 中。这样,下次打开页面时就可以正确地加载更新后的数据了。你可以使用类似以下的代码将更新后的数据保存回 questionsData 和 localStorage 中:
```
function saveData() {
// 获取表单中的值
const title = document.getElementById('title');
const type = document.getElementById('type');
const A = document.getElementById('A');
const B = document.getElementById('B');
const C = document.getElementById('C');
const D = document.getElementById('D');
const answer = document.getElementById('answer');
const score = document.getElementById('score');
// 根据表单中的值构造一个新的数据对象
const newData = {
title: title.value,
type: type.value,
options: {
A: A.value,
B: B.value,
C: C.value,
D: D.value,
},
answer: answer.value,
score: score.value,
};
// 更新 questionsData 数组中对应的数据
const index = questionsData.findIndex(q => q.title === newData.title && q.type === newData.type);
if (index !== -1) {
questionsData[index] = newData;
} else {
questionsData.push(newData);
}
// 将更新后的数据保存回 localStorage 中
localStorage.setItem('questionsData', JSON.stringify(questionsData));
// 清空表单
title.value = '';
type.value = '';
A.value = '';
B.value = '';
C.value = '';
D.value = '';
answer.value = '';
score.value = '';
// 显示更新后的数据
showData();
}
```
这样,在编辑完成并点击保存时,数据会被正确地更新,并重新显示在页面上。
阅读全文