jquery-todolist本地存储加载到页面

简介: jquery-todolist本地存储加载到页面

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);
                    }
                })
                //读取本地存储的数据
            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").empty();
                //遍历整个数据
                $.each(data, function(i, n) {
                    console.log(n);
                    $("ol").prepend("<li><input type='checkbox'><p>" + n.title + "</p><a href='javascript:;'></a></li>");
                })
            }
        });
    </script>
</body>
</html>

image.png

相关文章
|
11月前
|
JavaScript 前端开发
jQuery实现从一个页面跳转到另一个页面的指定tab选项卡
jQuery实现从一个页面跳转到另一个页面的指定tab选项卡
79 0
|
11月前
|
JavaScript
jQuery实现动态添加和删除(点击按钮添加在页面添加和删除元素)
jQuery实现动态添加和删除(点击按钮添加在页面添加和删除元素)
79 0
|
5月前
|
存储 JavaScript 小程序
jQuery、vue、小程序、uni-app中的本地存储数据和接受数据
jQuery、vue、小程序、uni-app中的本地存储数据和接受数据
60 0
|
JavaScript
Jquery插件知识之Jquery.cookie实现页面传值
Jquery插件知识之Jquery.cookie实现页面传值
57 0
|
JSON JavaScript 数据格式
jQuery操作页面元素属性和内容
jQuery操作页面元素属性和内容
54 0
|
2月前
|
JavaScript
分别用jquery和js修改页面元素
分别用jquery和js修改页面元素
32 2
|
3月前
|
移动开发 开发框架 JavaScript
基于Jquery WeUI的微信开发H5页面控件的经验总结(1)
基于Jquery WeUI的微信开发H5页面控件的经验总结(1)
|
2月前
|
JavaScript Java
分别使用java script和jQuery添加页面元素
分别使用java script和jQuery添加页面元素
31 0
|
3月前
|
移动开发 JSON JavaScript
基于Jquery WeUI的微信开发H5页面控件的经验总结(2)
基于Jquery WeUI的微信开发H5页面控件的经验总结(2)
|
缓存 前端开发 JavaScript
【前端用法】jquery获取当前页面的URL信息
【前端用法】jquery获取当前页面的URL信息
84 0