您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

JS实现简单的todoList(记事本)效果

51自学网 2022-05-02 21:34:14
  javascript

该记事本程序利用HTML+CSS+JavaScript前端三大框架来实现。

实现了记事本的添加,已完成删除待办事项的基本功能。

下面是程序实现的全部代码:

1.实现效果展示

2.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>

3.CSS代码

@font-face {  font-family: 'iconfont';  /* Project id 2680005 */  src: url('//at.alicdn.com/t/font_2680005_2v81j5og00f.woff2?t=1626424842361') format('woff2'),  url('//at.alicdn.com/t/font_2680005_2v81j5og00f.woff?t=1626424842361') format('woff'),  url('//at.alicdn.com/t/font_2680005_2v81j5og00f.ttf?t=1626424842361') format('truetype');} 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;}

4.Javascript代码

//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"    }  }}

在实现程序的时候,才发现明明有些代码都看得懂是什么意思,但是一到自己写的时候,就想不到应该这样完成。

我觉得归根结底,还是代码练的不够多,不能举一反三,融会贯通。

因此如果大家在看到这篇文章之后,也想做一个记事本的效果,建议大家自己动手敲一敲,毕竟代码只有自己动手敲了才知道缺陷和错误在哪里。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持wanshiok.com。


VUE引入使用G2图表的实现
vue3.0+vant3.0快速搭建项目的实现
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1