js 实现简单todo效果

代码
<!DOCTYPE html>
<html>
<head>
    <title></title>
<style>
    .done {
        color: red;
        text-decoration: line-through;
    }
</style>
</head>
<body>
<div class="todo-main">
    <div class="todo-form">
        <input id="id-input-todo" type="text">
        <button id="id-button-add" type="button">Add</button>
    </div>

    <!-- todo列表 -->
    <div id="id-div-container">

    </div>
</div>
</body>
<script>
    var log = function() {
        console.log.apply(console, arguments);
    }

    var $ = function(ele) {
        return document.querySelector(ele);
    }

    var todoList = [];

    var addButton = $('#id-button-add');
    addButton.addEventListener('click', function() {
        var todoInput = $('#id-input-todo');
        var task = todoInput.value;
        var todo = {
            'task': task,
            'time': currentTime()
        }
        todoList.push(todo);
        saveTodos();
        insertTodo(todo);
    });

    var insertTodo = function(todo) {
        var todoContainer = $('#id-div-container');
        var t = templateTodo(todo);
        todoContainer.insertAdjacentHTML('beforeend', t);
    };

    var templateTodo = function(todo) {
        var t = `
            <div class='todo-cell'>
                <button class='todo-done'>完成</button>
                <button class='todo-delete'>删除</button>
                <span contenteditable='true'>${todo.task}</span>
                <span>${todo.time}</span>
            </div>
        `
        return t;
    };

    var todoContainer = $('#id-div-container');
    todoContainer.addEventListener('keydown', function(event) {
        var target = event.target;
        if(event.key === 'Enter') {
            target.blur();
            event.preventDefault();
            var index = indexOfElement(target);
            todoList[index].task = target.innerHTML;
            saveTodos();
        }
    });


    todoContainer.addEventListener('click', function(event){
        log('container click', event, event.target);
        var target = event.target;
        if(target.classList.contains('todo-done')) {
            log('done');
            // 给 todo div 开关一个状态 class
            var todoDiv = target.parentElement;
            toggleClass(todoDiv, 'done');
        } else if (target.classList.contains('todo-delete')) {
            log('delete');
            var todoDiv = target.parentElement;
            var index = indexOfElement(target);
            log('delete index',  index);
            todoDiv.remove();
            // 把元素从 todoList 中 remove 掉
            // delete todoList[index]
            todoList.splice(index, 1);
            saveTodos();
        }
    });

    var saveTodos = function() {
        var s = JSON.stringify(todoList);
        localStorage.todoList = s;
    };

    var loadTodos = function() {
        var s = localStorage.todoList;
        return JSON.parse(s);
    };


    var indexOfElement = function(element) {
        var parent = element.parentElement;
        for(var i = 0; i < parent.children.length; ++i) {
            var e = parent.children[i];
            if (e === element) {
                return i;
            }
        }
    };

    var toggleClass = function(element, className) {
        if (element.classList.contains(className)) {
            element.classList.remove(className);
        } else {
            element.classList.add(className);
        }
    };



    var currentTime = function() {
        var d = new Date();
        var month = d.getMonth() + 1;
        var date = d.getDate();
        var hours = d.getHours();
        var minutes = d.getMinutes();
        var seconds = d.getSeconds();
        var timeString = `${month}/${date} ${hours}:${minutes}:${seconds}`;
        return timeString;
    };  


    todoList = loadTodos();
    for(var i = 0; i < todoList.length; ++i) {
        var todo = todoList[i];
        insertTodo(todo);
    }

</script>
</html>
效果

这里写图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值