您好,欢迎访问一九零五行业门户网

JS实现todolist详解

这次给大家带来js实现todolist详解,js实现todolist的注意事项有哪些,下面就是实战案例,一起来看一下。
本篇文章给大家介绍了通过原生javascript实现todolist功能相关知识点,对此有需要的朋友可以学习下。
该项目主要可以练习js操控dom,事件,事件触发之间的逻辑关系,以及如何写入缓存,获取缓存。
主要功能:
将用户输入添加至待办项
可以对todolist进行分类,用户勾选即将待办项分入已完成组
todolist的每一项可删除和编辑
将用户输入数据写入localstorage本地缓存,实现对输入数据的保存
可以清楚域名下本地缓存,并清空所有todolist项
具体功能的实现
html代码
<!doctype html> <html lang="en"> <head>  <meta charset="utf-8">  <title>todolist-prime</title>  <link rel="stylesheet" href="yuansheng.css" rel="external nofollow" > </head> <body>  <header>   <section>    <label for="add_list">my todolist</label>    <input type="text" id="add_list" name="add_list" placeholder="type here" required>   </section>  </header>  <p class="content">   <h1>未完成<span id="todocount"></span></h1>   <ol id="todolist">   </ol>   <h1>已完成<span id="donecount"></span></h1>   <ol id="donelist">   </ol>  </p>  <p id="clear">  <span style="white-space:pre;"> </span><button id="clearbutton"><h3>全部清除</h3></button>  </p>  <script src="todolist-prime.js"></script> </body> </html>
js代码及分析
创建一个数组对象来保存用户输入的数据,数组的每一项都是一个对象,对象的todo属性保存着用户输入的数据,done属性可理解为用户输入数据的标签,主要用来对todo值进行分类。
每次用户输入完数据,都要更新缓存,并初始化输入框。
function addtodolist(e) {  var obj_list = {   todo: , //用于存储用户输入的数据   done: false  //初始化用户输入的数据属性,以便对用户待办事项进行分类  };  document.getelementbyid(add_list).value = document.getelementbyid(add_list).value.trim();  if (document.getelementbyid(add_list).value.length === 0){   alert(不能为空);   return;  }  obj_list.todo = document.getelementbyid(add_list).value;  todolist.push(obj_list);  savedata(todolist);  document.getelementbyid(add_list).value = ;  //初始化输入框  load();  //将用户输入的数据添加至dom节点  document.getelementbyid(add_list).focus(); }
将输入的数据添加至dom节点,并且根据输入数据属性(done)的值进行分类。
<span style="font-size:14px;">function load(){  var todo = document.getelementbyid(todolist),   done = document.getelementbyid(donelist),   todocount = document.getelementbyid(todocount),   donecount = document.getelementbyid(donecount),   todostring = ,   donestring = ,   todocount = 0,   donecount = 0;  document.getelementbyid(add_list).focus();  todolist = loaddata();  //todolist数组对象里若包含用户输入数据,则将其添加至dom节点;若为空对象,则初始化页面。  if (todolist != null){   for (var i=0; i<todolist.length; i ++){ if(!todolist[i].done){ todostring += "<li> //通过onchange事件,复选框值有改变则调用update函数,并改变输入数据“done”属性的布尔值,这样 //下次load()后,这段数据会进入不同的分组,未完成的事项分入已完成事项组,已完成事项分入未完成事项组 //点击事项调用edit函数 //点击“-”,调用remove函数      + <input type='checkbox' onchange='update("+i+", \"done\", true)'>      + <p id='p-"+i+"' onclick='edit("+i+")'> + todolist[i].todo + </p> +      <a onclick='remove("+i+")'>-</a> +      </li>; //将每次用户输入的数据,通过节点<p>利用id标记,以便后续编辑功能定位     todocount ++;    }    else{     donestring += <li>      + <input type='checkbox' " + "onchange='update("+i+", \"done\", false)' checked>      + <p id='p-"+i+"' onclick='edit("+i+")'> + todolist[i].todo + </p>      + <a onclick='remove("+i+")'>-</a>      + </li>;     donecount ++;    }   }   todo.innerhtml = todostring;   done.innerhtml = donestring;   todocount.innerhtml = todocount;   donecount.innerhtml = donecount;  }  else {   todo.innerhtml = ;   done.innerhtml = ;   todocount.innerhtml = 0;   donecount.innerhtml = 0;  } }</span>
击事项触发编辑事件,将可编辑表单控件插入段落中,并将用户输入的值通过update函数对todolist数组里存储的数据进行更新
function edit(i) {  var p = document.getelementbyid('p-' + i),   pcontent = p.innerhtml,   inputid; //通过upadate函数对todolist数组相应项进行更新,将用户输入的内容写入到todolist数组相应项的todo属性中  function confirm() {   if (inputid.value.length === 0) {    p.innerhtml = pcontent;    alert(内容不能为空);   }   else {    update(i, todo, inputid.value); //修改事项内容后,更新数组里对应项todo属性的值,以便更新dom节点   }  } //结合keypress事件,按下enter键,调用confirm函数  function enter(e) {   if (e.keycode == 13){    confirm();   }  }  p.innerhtml = <input type='text' id='input-"+i+"' value='"+pcontent+"'>;  inputid = document.getelementbyid('input-'+i);  inputid.focus();  inputid.setselectionrange(0, inputid.value.length);  inputid.onblur = confirm; //表单控件失去焦点,调用confirm函数,即对页面内容进行更新  inputid.onkeypress = enter;  //对按键事件进行监控 }
将数组todolist相应项的属性(“todo”或“done”)进行更新,并加载
function update(i, field, value) {   todolist[i][field] = value;   savedata(todolist);   load();  }
删除相应项,并加载
function remove(i) {   todolist.splice(i, 1);     savedata(todolist); //相同名称的缓存会覆盖,更新缓存     load();  }
将用户数据保存至本地缓存
function savedata(data) {   localstorage.setitem(mytodolist, json.stringify(data)); //js对象转换成json对象存进本地缓存  }
从本地缓存中获取数据,有数据,赋值给todolist,这样刷新页面用户数据依旧存在
function loaddata() {   var history = localstorage.getitem(mytodolist);   if(history !=null){    return json.parse(history);  //json对象转换为js对象   }   else { return []; }  }
清楚本地缓存
function clear() {   localstorage.clear();   load();  }
一系列事件的监听
window.addeventlistener(load, load); //页面加载完毕调用load函数  document.getelementbyid(clearbutton).onclick = clear;  document.getelementbyid(add_list).onkeypress = function (event) {   if(event.keycode === 13){    addtodolist();   }  };
css
body {   margin: 0px;   padding: 0px;   font-size: 16px;   background-color: gainsboro; } header {   height: 50px;   background-color: cornflowerblue; } header section {   margin: 0 auto;   width: 40%; } header section label {   float: left;   line-height: 50px; /*设置line-height和包含块高度一致,以实现行内元素垂直居中*/   font-size: 20px; } #add_list {   float: right;   margin-top: 11px;   width: 60%;   height: 24px;   border-radius: 5px;   box-shadow: 0 1px 0 black;   font-size: 18px;   text-indent: 10px; } h1 {   position: relative; } h1 span {   position: absolute;   top: 1px;   right: 5px;   display: inline-block;   width: 23px;   height: 23px;   border-radius: 23px;  /*创建圆形标记*/   line-height: 23px;   font-size: 18px;   text-align: center;   background: #e6e6fa; } .content {   width: 40%;   margin: 0 auto; } li {   position: relative;   margin-bottom: 10px;   border-radius: 5px;   padding: 0 10px;   height: 32px;   box-shadow: 0 1px 0 black;   line-height: 32px;   background-color: burlywood;   list-style: none; } ol li input {   position: absolute;   top: 4px;   left: 10px;   width: 20px;   height: 20px;   cursor: pointer; } p{   margin: 0; } ol li p {   display: inline;   margin-left: 35px; } ol li p input{   top: 5px;   margin-left: 35px;   width: 70%;   height: 14px;   font-size: 14px;   line-height: 14px; } ol li a {   position: absolute;   top: 8px;   right: 10px;   display: inline-block;   border: 1px;   border-radius: 50%;   width: 16px;   height: 16px;   font-size: 32px;   line-height: 10px;   color: red;   font-weight: bolder;   cursor: pointer;   background-color: gray; } #clear {   width: 100px;   margin: 0 auto; } #clearbutton {   border-color: red;   border-radius: 5px;   box-shadow: 0 1px 0 yellow;   cursor: pointer; } button h3{   font-size: 13px;   line-height: 13px; }
最后的实现效果
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
react native使用fetch上传图片
使用import 和require打包js
react事件绑定this的几种方式
以上就是js实现todolist详解的详细内容。
其它类似信息

推荐信息