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

 更新时间:2021年09月10日 11:48:07   作者:小周程序媛  
这篇文章主要为大家详细介绍了JS实现简单的todoList(记事本)效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

该记事本程序利用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"
    }
  }
}

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

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

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

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

相关文章

  • Fetch超时设置与终止请求详解

    Fetch超时设置与终止请求详解

    这篇文章主要给大家介绍了关于Fetch超时设置与终止请求的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Fetch具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-05-05
  • 一文详解Javascript内存机制与垃圾回收

    一文详解Javascript内存机制与垃圾回收

    这篇文章主要给大家详细介绍了Javascript的内存机制与垃圾回收,文中又详细的代码示例,对我们学习Javascript有一定的帮助,需要的同学可以借鉴阅读
    2023-06-06
  • js判断鼠标左、中、右键哪个被点击的方法

    js判断鼠标左、中、右键哪个被点击的方法

    这篇文章主要介绍了js判断鼠标左、中、右键哪个被点击的方法,主要通过event.button事件来判断鼠标点击的类型,需要的朋友可以参考下
    2015-01-01
  • 原生Javascript和jQuery做轮播图简单例子

    原生Javascript和jQuery做轮播图简单例子

    这篇文章主要为大家详细介绍了原生Javascript和jQuery做轮播图简单例子,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • js实现带积分弹球小游戏

    js实现带积分弹球小游戏

    这篇文章主要为大家详细介绍了js实现带积分弹球小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-07-07
  • 原生JS实现动态添加新元素、删除元素方法

    原生JS实现动态添加新元素、删除元素方法

    这篇文章主要介绍了原生js实现动态添加新元素、删除元素方法 ,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • JavaScript实现图片伪异步上传过程解析

    JavaScript实现图片伪异步上传过程解析

    这篇文章主要介绍了javascript实现图片伪异步上传过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • javascript实现拍照功能详细示例代码

    javascript实现拍照功能详细示例代码

    这篇文章主要给大家介绍了关于javascript实现拍照功能的相关资料, 最近做项目,遇到一个正常但又少见的需求之拍照,文中给出了详细的代码示例,需要的朋友可以参考下
    2023-07-07
  • javascript 运算数的求值顺序

    javascript 运算数的求值顺序

    请注意,这里说的是运算数的求值顺序。而非运算符,运算符的求值顺序我们比较熟悉。
    2011-08-08
  • JavaScript/TypeScript中==和===的区别详解

    JavaScript/TypeScript中==和===的区别详解

    这篇文章主要给大家介绍了关于JavaScript/TypeScript中==和===区别的相关资料,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-03-03

最新评论