ToDoList:本地存储知识最简单的代办事项列表

$(function () {
  //   alert(11);
  // 1.按下回车 把完整数据 存储到本地存储里面
  // 存储的数据格式 var = todolist = [{title:'xxx',done:false}]
  load();
  $("#title").on("keydown", function (event) {
    if (event.keyCode === 13) {
      if ($(this).val() === "") {
        alert("请输入您要的操作");
      } else {
        var local = getDate();
        console.log(local);
        // 把Local数组进行更新数据把最新的数据追加给Local数组
        local.push({ title: $(this).val(), done: false });
        //把这个数组的local存储给本地存储
        saveDate(local);
        // 2.toDoList 本地存储数据渲染加载到页面
        load();
        $(this).val("");
      }
    }
  });
  // 3.toDoList 删除操作
  $("ol").on("click", "a", function () {
    var data = getDate();
    // 修改数据
    var index = $(this).attr("id");
    data.splice(index, 1);
    // 保存到本地存储
    saveDate(data);
    // 重新渲染页面
    load();
  });
  // 4.toDoList 正在进行和已完成选项操作
  $("ol,ul").on("click", "input", function () {
    // 先获取本地存储的数据
    var data = getDate();
    // 修改数据
    var index = $(this).siblings("a").attr("id");
    //   data[].done = ?
    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();
    // 遍历之前先清空ol里面的元素内容
    $("ol,ul").empty();
    var todoCount = 0; //进行
    var doneCount = 0; //完成

    // 遍历这个数据
    $.each(data, function (i, n) {
      if (n.done) {
        $("ul").prepend(
          "<li><input type ='checkbox' checked ='checked'> <p>" +
            n.title +
            "</p> <a href = 'javascript:;' id=" +
            i +
            "></a></li>"
        );
        doneCount++;
      } else {
        $("ol").prepend(
          "<li><input type ='checkbox'> <p>" +
            n.title +
            "</p> <a href = 'javascript:;' id=" +
            i +
            "></a></li>"
        );
        todoCount++;
      }
    });
    $("#todocount").text(todoCount);
    $("#donecount").text(doneCount);
  }
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不停喝水

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值