此系列的最后一天學(xué)習(xí)了,來(lái)把任務(wù)管理做得更完善點(diǎn)。
今日目標(biāo),是添加標(biāo)簽列,以及根據(jù)標(biāo)簽過(guò)濾任務(wù)。
添加標(biāo)簽
還記得昨天添加優(yōu)先級(jí)是如何完成的嗎?
這里可以先暫停閱讀,自己根據(jù)昨天的實(shí)現(xiàn),先自己思考一下。
這里要做的事情如下:
添加標(biāo)簽元素
在任務(wù)輸入框旁邊添加一個(gè)輸入框,用于輸入任務(wù)標(biāo)簽。
<input type="text" id="tag-input" placeholder="輸入標(biāo)簽" />
為標(biāo)簽添加樣式
為任務(wù)標(biāo)簽添加樣式。
#tag-input { width: 100px; padding: 10px; margin-right: 10px; border: 1px solid #ccc; border-radius: 4px; }
標(biāo)簽存儲(chǔ)
在添加任務(wù)時(shí),獲取標(biāo)簽并將其存儲(chǔ)和顯示。
//1. 獲取標(biāo)簽元素 const tagInput = document.getElementById('tag-input'); function loadTasks() { const tasks = JSON.parse(localStorage.getItem('tasks')) || []; tasks.forEach((task) => { addTaskToDOM(task.text, task.priority, task.tag, task.completed); }); } function saveTasks() { const tasks = []; document.querySelectorAll('.task').forEach((task) => { tasks.push({ text: task.querySelector('.task-text').textContent, priority: task.dataset.priority, //添加標(biāo)簽 tag: task.dataset.tag, completed: task.classList.contains('completed'), }); }); localStorage.setItem('tasks', JSON.stringify(tasks)); } //添加新的參數(shù)taskTag用于傳遞標(biāo)簽值 function addTaskToDOM(taskText, taskPriority, taskTag, completed = false) { const newTask = document.createElement('li'); newTask.className = `task ${taskPriority}`; newTask.dataset.priority = taskPriority; //添加標(biāo)簽 newTask.dataset.tag = taskTag; if (completed) { newTask.classList.add('completed'); } const taskTextSpan = document.createElement('span'); taskTextSpan.className = 'task-text'; taskTextSpan.textContent = taskText; //添加標(biāo)簽 const taskTagSpan = document.createElement('span'); taskTagSpan.className = 'task-tag'; taskTagSpan.textContent = ` [${taskTag}]`; const completeBtn = document.createElement('button'); completeBtn.textContent = '完成'; completeBtn.className = 'complete-btn'; completeBtn.addEventListener('click', () => { newTask.classList.toggle('completed'); saveTasks(); }); const deleteBtn = document.createElement('button'); deleteBtn.textContent = '刪除'; deleteBtn.className = 'delete-btn'; deleteBtn.addEventListener('click', () => { taskList.removeChild(newTask); saveTasks(); }); newTask.appendChild(taskTextSpan); //添加標(biāo)簽 newTask.appendChild(taskTagSpan); newTask.appendChild(completeBtn); newTask.appendChild(deleteBtn); taskList.appendChild(newTask); }
根據(jù)標(biāo)簽過(guò)濾
實(shí)現(xiàn)標(biāo)簽篩選功能,需要做如下事情:
添加標(biāo)簽過(guò)濾元素
在頁(yè)面上添加一個(gè)輸入框或選擇框,用于輸入或選擇要篩選的標(biāo)簽。
<div class="container"> <select id="filter-select"> <option value="all">所有標(biāo)簽</option> </select> </div>
實(shí)現(xiàn)標(biāo)簽過(guò)濾功能
//獲取標(biāo)簽過(guò)濾按鈕元素并添加change事件監(jiān)聽 const filterSelect = document.getElementById('filter-select'); filterSelect.addEventListener('change', filterTasks); function loadTasks() { const tasks = JSON.parse(localStorage.getItem('tasks')) || []; tasks.forEach((task) => { addTaskToDOM(task.text, task.priority, task.tag, task.completed); //把標(biāo)簽值添加到過(guò)濾列表里 addTagToFilter(task.tag); }); } function addTagToFilter(tag) { if ( !Array.from(filterSelect.options).some((option) => option.value === tag) ) { const option = document.createElement('option'); option.value = tag; option.textContent = tag; filterSelect.appendChild(option); } } function filterTasks() { const filter = filterSelect.value; document.querySelectorAll('.task').forEach((task) => { if (filter === 'all' || task.dataset.tag === filter) { task.style.display = ''; } else { task.style.display = 'none'; } }); }
總結(jié)
代碼差異對(duì)比:
這樣整個(gè) JavaScript 入門學(xué)習(xí)的基礎(chǔ)知識(shí)就告一段落。
在 JS 學(xué)習(xí)里,入門時(shí)強(qiáng)調(diào)了實(shí)踐。
在實(shí)踐過(guò)程中,如果有些東西不好理解,也沒有關(guān)系,先知道如何使用。
實(shí)踐的多了,就理解了,跟書讀百遍是一個(gè)意思。
那就先這樣吧。
該文章在 2024/11/5 9:22:08 編輯過(guò)