⊗jsPrChLRCB 19 of 62 menu

Кнопкі для выдалення і завяршэння ў чэклісце на JavaScript

У папярэднім уроку пасля рашэння задач у вас павінен быў атрымацца наступны код:

<input id="input"> <ul id="list"></ul> let input = document.querySelector('#input'); let list = document.querySelector('#list'); input.addEventListener('keypress', function(event) { if (event.key == 'Enter') { let li = document.createElement('li'); li.textContent = this.value; list.appendChild(li); this.value = ''; } });

Давайце цяпер дадамо кнопачкі 'выдаліць' і 'зроблена'. Выканаем гэтыя кнопачкі у выглядзе тэгаў span. Таксама ў тэгу span размясцім і тэкст справы:

input.addEventListener('keypress', function(event) { if (event.key == 'Enter') { let li = document.createElement('li'); let task = document.createElement('span'); task.textContent = this.value; li.appendChild(task); let remove = document.createElement('span'); remove.textContent = 'выдаліць'; li.appendChild(remove); let mark = document.createElement('span'); mark.textContent = 'зроблена'; li.appendChild(mark); list.appendChild(li); this.value = ''; } });

Давайце таксама навясім CSS класы на кожны з тэгаў span, каб да іх можна было звярнуцца праз CSS і навесці патрэбную нам прыгажосць:

let input = document.querySelector('#input'); let list = document.querySelector('#list'); input.addEventListener('keypress', function(event) { if (event.key == 'Enter') { let li = document.createElement('li'); let task = document.createElement('span'); task.classList.add('task'); task.textContent = this.value; li.appendChild(task); let remove = document.createElement('span'); remove.classList.add('remove'); remove.textContent = 'выдаліць'; li.appendChild(remove); let mark = document.createElement('span'); mark.classList.add('mark'); mark.textContent = 'зроблена'; li.appendChild(mark); list.appendChild(li); this.value = ''; } });

Дадамо CSS да навешаных класаў:

#list span { margin-right: 5px; } #list .remove, #list .mark { color: blue; cursor: pointer; } #list .remove:hover, #list .mark:hover { text-decoration: underline; }
azbydeenesfrkakkptruuz