Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 12.02.2018, 13:07
Аспирант
Отправить личное сообщение для marc Посмотреть профиль Найти все сообщения от marc
 
Регистрация: 02.12.2017
Сообщений: 81

Не срабатывает фуннкция очистки onClear
Привет, есть код, при нажатии на кнопку "Clear" должны очиститься все элемент в списке, что у меня не так?
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <link href="https://use.fontawesome.com/releases/v5.0.6/css/all.css" rel="stylesheet">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
</head>
<body>
<section class="todo-list-wrapper mt-5">
    <div class="container">
        <div class="card mb-3">
            <div class="card-header">
                Add todo
            </div>
            <div class="card-body">
                <form name="addTodoItem">
                    <div class="form-group">
                        <label for="todo">Text</label>
                        <input type="text" class="form-control" id="todo">
                        <div class="invalid-feedback">
                            Please enter some text.
                        </div>
                    </div>
                    <button type="submit" class="btn btn-primary btn-block">Add</button>
                </form>
            </div>
        </div>
        <div class="card">
            <div class="card-header">
                Todo list
            </div>
            <ul class="list-group list-group-flush"></ul>
        </div>
        <button class="btn btn-primary mt-3 clear-list">Clear</button>
    </div>
</section>

<script src="main.js"></script>
</body>
</html>

let tasks = [
    "Выучить JavaScript",
    "Выучить Angular 4",
    "Выучить React"
];

let ul = document.querySelector('.list-group');
let form = document.forms['addTodoItem'];
let addInput = form['todo'];
let clearBtn = document.querySelector('.clear-list');



function listTemplate(task) {
    //create tag li
    let li = document.createElement('li');
    li.innerText = task;
    li.className = 'list-group-item d-flex';
    //create tag i
    let i = document.createElement('i');
    i.className = 'fas fa-trash-alt ml-auto remove-list-item removeBtns';
    //append i to li
    li.appendChild(i);
    //return element i
    return li;
}

let removeBtns = document.getElementsByClassName('removeBtns');

function generateList(tasksArray) {
    clearList();

    for ( let i = 0; i < tasksArray.length; i++){
        let liTemplate = listTemplate(tasksArray[i]);
        ul.appendChild(liTemplate);
    }

    setListeners();
}

function addTask(string) {
    if ( !string || typeof string !== 'string') return new Error('Не передана строка');
    if ( !string.length ) return new Error('Строка не должна быть пустой');

    tasks.unshift(string);

    generateList(tasks);
}

function clearList() {
    ul.innerHTML = '';
}

function editTask(task, updtask) {

    let currentTask = tasks.indexOf(task);
    tasks[currentTask] = updtask;
    generateList(tasks);


}

function deleteTask(task) {
    let currentTask = tasks.indexOf(task);
    console.log(currentTask, task.length, task);

    if( currentTask !== -1){
        tasks.splice(currentTask, 1);
        ul.children[currentTask].remove();
    } else {
        console.warn('Задача не обнаружена');
    }
}

function setListeners() {

    //set listeners at remove btns
    for ( let i = 0; i < removeBtns.length; i++){
        removeBtns[i].addEventListener('click', function (e) {
            let parent = this.closest('li');
            deleteTask(parent.textContent);
        });
    }
}

function onSubmit(e) {
    e.preventDefault();

    if ( !addInput.value ){
        addInput.classList.add('is-invalid')
    } else {
        addInput.classList.remove('is-invslid');
        addTask(addInput.value);
        form.reset();
    }
    console.dir(addInput);
}

function onClear(e) {
    tasks = [];
    ul.innerHTML = '';
}

form.addEventListener('submit', onSubmit);

clearBtn.addEventListener('submit', onClear);


//Генерация списка при загрузке страницы
generateList(tasks);
Ответить с цитированием
  #2 (permalink)  
Старый 12.02.2018, 13:26
Профессор
Отправить личное сообщение для Nexus Посмотреть профиль Найти все сообщения от Nexus
 
Регистрация: 04.12.2012
Сообщений: 3,791

Сообщение от marc
что у меня не так?
clearBtn.addEventListener('submit', onClear);

submit на click поменяйте.
Ответить с цитированием
  #3 (permalink)  
Старый 12.02.2018, 14:20
Аватар для ksa
ksa ksa вне форума
CacheVar
Отправить личное сообщение для ksa Посмотреть профиль Найти все сообщения от ksa
 
Регистрация: 19.08.2010
Сообщений: 14,209

Или вместо кнопки, повесить событие туда, куда нужно - на форму.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Таймер срабатывает раньше времени или вообще не срабатывает Terebonko Элементы интерфейса 6 03.08.2017 12:43
Почему не срабатывает функция внутри функции? Conus Элементы интерфейса 1 17.04.2016 15:50
onclick срабатывает со 2 раза в ie djonA Общие вопросы Javascript 19 25.03.2013 01:07
AJAX запрос в Internet Explorer срабатывает через раз nikolayseo jQuery 5 13.11.2012 00:13
Нажатие по дате в календаре срабатывает только со второго клика afr0 Events/DOM/Window 4 31.10.2012 13:39