js实现简单todo-list | 青训营

351 阅读5分钟

实现一个todolist,具备以下核心功能:

  1. 任务添加与编辑: 用户可以通过界面添加新的待办任务,并有能力随时编辑已有任务的内容。

  2. 任务完成与归档: 用户可以将已完成的任务标记为完成状态,同时保留对这些任务的访问权限,以供日后参考。

  3. 任务删除: 删除已添加任务。

技术实现

为了实现上述功能,使用JavaScript作为核心编程语言,实现交互功能,使用HTML和CSS来构建应用的用户界面。

效果展示

image.png

实现代码

HTML部分

<head>
  <meta charset="UTF-8">
  <title>TodoList</title>
//导入css文件
  <link rel="stylesheet" href="todoList.css">
</head>
<body>
<div class="myhead">
   <h2>My ToDo List</h2>
  <table>
    <tr>
      <td><input type="text" placeholder="请输入待办事项..." id="things"></td>
      <td> <span id="add" onclick="addElement()">add</span></td>
    </tr>
  </table>
</div>
 
//待办事项部分,内容动态生成
  <ul></ul>
 
<div class="test2"></div>
</body>
<!--将JavaScript元素放在后面,否则在执行JavaScript的时候,dom树还未构建,会出现意想不到的错误-->
<script src="todoList.js" type="text/javascript"></script>
</html>

CSS部分

body {
  margin: 0;
  padding: 0;
}
*{
  box-sizing: border-box;
}
.myhead{
   background-color: lightpink;
   text-align: center;
   padding: 5px 0px 10px 0px;
   color: aliceblue;
 }
  table{
  margin: 0 auto;
}
 #things{
   width: 180px;
   height: 30px;
   border-radius: 3px;
   outline: none;
   border: solid 1px white;
 }
 #add{
   display: inline-block;
   width: 80px;
   height: 30px;
   background-color: gainsboro;
   color: grey;
   border-radius: 3px;
   line-height: 30px;
 }
  #add:hover{
    cursor: pointer;
    background-color:darkgrey ;
    color: grey;
  }
ul{
  margin: 0px;
  padding: 0px;
}
  ul li{
    list-style: none;
    /*text-align: center;*/
    position: relative;
    padding-left:40px;
    height: 40px;
    line-height: 40px;
  }
  ul li:nth-child(odd) {
  background-color: #f9f9f9;
}
  ul li:hover{
  cursor: pointer;
  background-color: #dddddd;
}
 
  ul li.check{
  background-color: #888888;
  text-decoration: line-through;
  color: #f9f9f9;
}
  ul li.check::before{
 
    content: '';
    position: absolute;
    border-color: #fff;
    border-style: solid;
    border-width: 0 2px 2px 0;
    top: 10px;
    left: 16px;
 
    transform: rotate(45deg);
    height: 15px;
    width: 7px;
}
.close{
  position: absolute;
  right: 0px;
  top: 0px;
  padding: 0px 20px;
  font-size: 16px;
}
.close:hover{
  background-color: #f44336;
  color: white;
}

javascript部分

主要包含了以下功能:

  1. 获取待办事项列表并为每个列表项添加一个关闭按钮:

    • 通过 document.getElementsByTagName("li") 获取所有 <li> 元素,即待办事项列表项。
    • 使用一个 for 循环遍历所有列表项。
    • 在每个列表项中创建一个 <span> 元素作为关闭按钮。
    • 创建一个文本节点 "\u00D7" 表示一个叉号 (×),表示删除操作。
    • 给创建的 <span> 添加 close 类名。
    • 将文本节点添加到 <span> 中。
    • <span> 添加到当前列表项中。
  2. 处理关闭按钮点击事件:

    • 通过 document.getElementsByClassName("close") 获取所有拥有 close 类名的元素,即关闭按钮。
    • 使用一个 for 循环遍历所有关闭按钮。
    • 为每个关闭按钮添加一个点击事件处理函数。
    • 在点击事件处理函数中,通过 this.parentElement 获取当前点击按钮的父元素节点,即列表项,然后将其样式的 display 设为 "none",使其隐藏。
  3. 处理任务完成事件:

    • 通过 document.querySelector("ul") 获取 <ul> 元素,即待办事项列表的父元素。
    • 使用事件委托,将点击事件绑定在 <ul> 上,以便在点击不同的列表项时触发事件。
    • 在事件处理函数中,检查点击的元素是否是 <li> 元素(通过 ev.target.tagName)。
    • 如果点击的是 <li> 元素,通过 ev.target.classList.toggle('check') 切换添加/移除 check 类名,从而改变任务完成状态的样式。
  4. 处理添加新待办事项事件:

    • 定义一个名为 addElement 的函数,用于处理添加新待办事项的操作。
    • 获取输入框中的待办事项内容。
    • 创建一个新的 <li> 元素。
    • 创建一个文本节点,将待办事项内容作为文本节点的内容。
    • 如果输入框内容为空,弹出提示要求输入待办事项。
    • 否则,将文本节点添加到新创建的 <li> 元素中,再将 <li> 添加到待办事项列表中。
    • 创建一个 <span> 元素作为关闭按钮,类似之前的操作。
    • 将关闭按钮添加到新的列表项中。
    • 针对新添加的关闭按钮,同样为其添加点击事件处理函数,用于删除相应的列表项。

实现了一个简单的待办事项列表应用,可以添加新的待办事项、标记任务完成状态以及删除待办事项。通过事件委托和动态创建元素,实现了一个基本的互动界面。

//1.在每个span后面添加close节点
var myNodelist=document.getElementsByTagName("li")
 
for (var i=0;i<myNodelist.length;i++)
{
  var span=document.createElement("span");
 
  var txt=document.createTextNode("\u00D7");
 
  span.className="close";
  span.appendChild(txt);
  myNodelist[i].appendChild(span);
 
}
 
//2.处理删除事件
var close=document.getElementsByClassName("close")
for (var i=0;i<close.length;i++)
{
  close[i].onclick=function () {
    //parentElement表示返回当前节点的父元素节点
    var div=this.parentElement
    div.style.display="none"
  }
}
 
//3.处理任务完成事件
var list=document.querySelector("ul")
console.log(list)
list.addEventListener('click',function (ev) {
//event.target属性可以用来实现事件委托,例如将事件绑定在ul上,但是点击li时可以被触发
  //tagName是获取元素的标签名
  if (ev.target.tagName === 'LI')
{
  //toggle方法在被选元素上进行hide()和show()之间的切换
  //classList对元素的class继续操作
  ev.target.classList.toggle('check')
}
},false);
 
//4.处理点击add按钮,列表中添加一个待办事项
 
function addElement(){
  var things=document.getElementById('things').value
 
 // alert(localStorage.setItem("mutodolist",JSON.stringify(things)))
 
  var li=document.createElement('li')
 
  var t=document.createTextNode(things)
 
  if (things == '')
  {
    alert("请输入待办事件")
  }
  else
  {
    list.appendChild(li)
    li.appendChild(t)
  }
 
  var span=document.createElement('span')
  var txt=document.createTextNode('\u00D7')
 
  span.className='close'
  span.appendChild(txt)
  li.appendChild(span)
 
  for (var i=0;i<close.length;i++)
  {
    close[i].onclick=function () {
      var div=this.parentElement
      div.style.display="none"
    }
  }
}

需要注意的是,这段代码中没有涉及持久化数据,刷新页面后待办事项会被重置。可以使用localStorage或其他浏览器存储机制,将任务保存在浏览器中,使得刷新后仍然看得到之前添加的任务。

当然,这只是使用Javascript实现的简单的todolist,在实现程序的时候,我发现平时明明有些代码都看得懂是什么意思,但是一到自己写的时候,就想不到应该这样完成。我觉得归根结底,还是代码练的不够多,不能举一反三,融会贯通。

如果大家在看到这篇文章之后,也想做一个todolist的效果,建议大家自己动手敲一敲,毕竟代码只有自己动手敲了才知道缺陷和错误在哪里。也可以对todolist进行进一步的完善,比如添加一些搜索功能,编辑任务,排序任务等等。也通过一点一点实现这个案例,我们的javascript基本功会越来越稳固。