todolist正在进行和已经完成阶段2-69

简介: todolist正在进行和已经完成阶段2-69

image.png

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>todoList待办事项</title>
    <script src="./js/jquery.min.js"></script>
</head>
<body>
    <header>
        <section>
            <label for="title">ToDoList</label>
            <input type="text" id="title" placeholder="添加ToDo">
        </section>
    </header>
    <section>
        <h2>正在进行<span id="rodocount"></span></h2>
        <ol id="todolist" class="demo-box">
        </ol>
        <h2>已经完成<span id="rodocount"></span></h2>
        <ul id="donelist">
        </ul>
    </section>
    <footer>
        Copyright &copy;2014 todolist.cn
    </footer>
    <script>
        var todolist = [{
            title: '我今天吃了八个馒头',
            done: false
        }, {
            title: '我今天学习jq',
            done: false
        }, ];
        localStorage.setItem("todo", JSON.stringify(todolist));
        //本地的数组转换为json.stringfy();
        var data = localStorage.getItem("todo");
        console.log(typeof data);
        //获取本地存储数据需要把字符串数据转换为对象形式json.parse
        data = JSON.parse(data);
        console.log(data);
        $(function() {
            //todolist渲染到界面
            load();
            //按下回车 把完整数据存储到本地存储里面
            $("#title").on("keydown", function(event) {
                if (event.keyCode === 13) {
                    //先读取本地存储原来的数据
                    var local = getDate();
                    console.log(local);
                    //把local数组更新元素
                    local.push({
                        title: $(this).val(),
                        done: false
                    });
                    //把这个数组给本地存储
                    saveDate(local);
                    //todolist渲染到界面
                    load();
                }
            });
            //todolist删除事件
            $("ol").on("click", "a", function() {
                //获取本地存储
                var data = getDate();
                console.log(data);
                //修改数据
                var index = $(this).attr("id");
                console.log(index);
                //保存到本地存储
                data.splice(index, 1);
                //渲染
                saveDate(data);
                load();
            });
            //正在进行和已完成
            $("ol,ul").on("click", "input", function() {
                    //获取本地存储的数据
                    var data = getDate();
                    //修改数据
                    var index = $(this).siblings("a").attr("id");
                    //
                    data[index].done = $(this).prop("checked");
                    // console.log(data);
                    //保存到本地存储
                    saveDate(data);
                    //渲染
                    load();
                })
                //读取本地存储的数据
            function getDate() {
                var data = localStorage.getItem("todolist");
                if (data !== null) {
                    //本地存储里面的数据是字符串格式的
                    return JSON.parse(data);
                } else {
                    //返回一个数组
                    return [];
                }
            }
            //保存数据
            function saveDate(data) {
                localStorage.setItem("todolist", JSON.stringify(data));
            }
            //渲染数据
            function load() {
                //读取本地的数据
                var data = getDate(data);
                console.log(data);
                //遍历之前清空
                $("ol,ul").empty();
                //遍历整个数据
                $.each(data, function(i, n) {
                    //console.log(n);
                    if (n.done) {
                        $("ul").prepend("<li><input type='checkbox' checked='checked'><p>" + n.title +
                            "</p><a href='javascript:;' id=" + i + ">删除</a></li>");
                    } else {
                        $("ol").prepend("<li><input type='checkbox'><p>" + n.title +
                            "</p><a href='javascript:;' id=" + i + ">删除</a></li>");
                    }
                })
            }
        });
    </script>
</body>
</html>

image.png

相关文章
|
2月前
|
前端开发
利用React Hooks优化前端状态管理
本文将深入介绍如何利用React Hooks优化前端状态管理,包括Hooks的概念、使用方法以及与传统状态管理方式的对比分析,帮助前端开发人员更好地理解和应用这一现代化的状态管理方案。
|
4月前
|
JavaScript
深入理解 Vue.js 中的`mapState`辅助函数:简化状态管理的秘密武器(上)
深入理解 Vue.js 中的`mapState`辅助函数:简化状态管理的秘密武器(上)
|
4月前
|
JavaScript
深入理解 Vue.js 中的`mapState`辅助函数:简化状态管理的秘密武器(下)
深入理解 Vue.js 中的`mapState`辅助函数:简化状态管理的秘密武器(下)
深入理解 Vue.js 中的`mapState`辅助函数:简化状态管理的秘密武器(下)
|
9月前
|
前端开发 JavaScript
说说React生命周期有哪些不同的阶段?每个阶段对应的方法是?
说说React生命周期有哪些不同的阶段?每个阶段对应的方法是?
|
9月前
|
前端开发
前端学习笔记202307学习笔记第六十天-react源码-从render到commit阶段2
前端学习笔记202307学习笔记第六十天-react源码-从render到commit阶段2
41 0
|
4月前
|
前端开发
第二十四章 案例TodoList 之props限制
第二十四章 案例TodoList 之props限制
|
5月前
|
JavaScript
vue每个阶段的生命周期做了什么
vue每个阶段的生命周期做了什么
27 0
|
6月前
|
JavaScript
Vue的生命周期(简单的过程)
Vue的生命周期(简单的过程)
23 0
|
9月前
|
前端开发 JavaScript
【 说说React生命周期有哪些不同的阶段?每个阶段对应的方法是?】
【 说说React生命周期有哪些不同的阶段?每个阶段对应的方法是?】

热门文章

最新文章