jQuery模仿ToDoList实现简单的待办事项列表
功能:在文本框中输入待办事项按下回车后,事项会出现在未完成列表中;点击未完成事项前边的复选框后,该事项会出现在已完成列表中,反之亦然;点击删除按钮会删除该事项;双击事项可以修改事项的内容。待办事项的数据是保存到本地存储的(localStorage),就算关闭页面再打开,数据还是存在的(前提是要用相同浏览器)。
ToDoList链接:ToDoList—最简单的待办事项列表
先把css样式以及js文件引入进来,jQuery文件要写在你自己的js文件上边
<link rel="stylesheet" href="css/index.css">
<script src="js/jquery.min.js"></script>
<script src="js/todolist.js"></script>
HTML代码:
<body>
<header>
<section>
<label for="title">ToDoList</label>
<input type="text" id="title" name="title" placeholder="添加ToDo" required="required" autocomplete="off" />
</section>
</header>
<section>
<h2>正在进行 <span id="todocount"></span></h2>
<ol id="todolist" class="demo-box"> </ol>
<h2>已经完成 <span id="donecount"></span></h2>
<ul id="donelist"> </ul>
</section>
<footer>
Copyright © 2019
</footer>
</body>
body {
margin:;
padding:;
font-size: 16px;
background: #CDCDCD;
} header {
height: 50px;
background: #333;
background: rgba(47, 47, 47, 0.98);
} section {
margin: 0 auto;
} label {
float: left;
width: 100px;
line-height: 50px;
color: #DDD;
font-size: 24px;
cursor: pointer;
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
} header input {
float: right;
width: 60%;
height: 24px;
margin-top: 12px;
text-indent: 10px;
border-radius: 5px;
box-shadow: 0 1px 0 rgba(255, 255, 255, 0.24), 0 1px 6px rgba(0, 0, 0, 0.45) inset;
border: none
} input:focus {
outline-width: 0
} h2 {
position: relative;
} span {
position: absolute;
top: 2px;
right: 5px;
display: inline-block;
padding: 0 5px;
height: 20px;
border-radius: 20px;
background: #E6E6FA;
line-height: 22px;
text-align: center;
color: #666;
font-size: 14px;
} ol,
ul {
padding:;
list-style: none;
} li input {
position: absolute;
top: 2px;
left: 10px;
width: 22px;
height: 22px;
cursor: pointer;
} p {
margin:;
} li p input {
top: 3px;
left: 40px;
width: 70%;
height: 20px;
line-height: 14px;
text-indent: 5px;
font-size: 14px;
} li {
height: 32px;
line-height: 32px;
background: #fff;
position: relative;
margin-bottom: 10px;
padding: 0 45px;
border-radius: 3px;
border-left: 5px solid #629A9C;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.07);
} ol li {
cursor: move;
} ul li {
border-left: 5px solid #999;
opacity: 0.5;
} li a {
position: absolute;
top: 2px;
right: 5px;
display: inline-block;
width: 14px;
height: 12px;
border-radius: 14px;
border: 6px double #FFF;
background: #CCC;
line-height: 14px;
text-align: center;
color: #FFF;
font-weight: bold;
font-size: 14px;
cursor: pointer;
} footer {
color: #666;
font-size: 14px;
text-align: center;
} footer a {
color: #666;
text-decoration: none;
color: #999;
} @media screen and (max-device-width: 620px) {
section {
width: 96%;
padding: 0 2%;
}
} @media screen and (min-width: 620px) {
section {
width: 600px;
padding: 0 10px;
}
}
index.css
接下来开始写我们自己的js代码
将多次使用的代码封装成函数,方便使用
①获取本地存储的数据。如果本地有数据则直接获取过来,没有数据的话就返回一个空数组
function getDate() {
var data = localStorage.getItem("todolist"); // 将获取到的数据赋给data
if(data !== null) { // 如果本地有数据,则返回数据
return JSON.parse(data); // 本地存储只能存储字符串,所以要想获取里边的数据就必须将字符串转换为数组形式返回
} else {
return []; // 如果本地没有数据,则返回一个空数组
}
}
②保存本地存储数据
function saveDate(data) {
// 用JSON.stringify()将数组转化成字符串保存到本地存储
localStorage.setItem("todolist", JSON.stringify(data));
}
③渲染页面 加载数据
先将本地存储数据获取过来;将他们遍历(遍历之前先将列表清空),看他们是否已经被完成(通过数组里我们自己添加的done的值为true还是false来判断),如果已经被完成则添加到ul列表,否则添加进ol列表里;同时声明两个变量来保存已完成和未完成事项的个数
function load() {
var data = getDate(); // 先获取本地存储数据 // 遍历本地存储数据 将他们添加到列表中
$("ol, ul").empty(); // 遍历之前先清空列表
var doneCount = 0; // 已经完成的个数
var todoCount = 0; // 正在进行的个数
$.each(data, function(i, ele) { // i为索引 ele为遍历对象
// 如果复选框被选中(已完成done: true)添加到ul里,未被选中(未完成done: false)添加到ol里
if(ele.done) {
$("ul").prepend("<li><input type='checkbox' checked='checked' > <p>" + ele.title + "</p> <a href='javascript:;' index=" + i + "></a></li>");
doneCount++; // 每添加一个li,已完成数加一
} else {
$("ol").prepend("<li><input type='checkbox'> <p>" + ele.title + "</p> <a href='javascript:;' index=" + i + "></a></li>");
todoCount++;
}
})
$("#donecount").text(doneCount);
$("#todocount").text(todoCount);
}
1. 用户输入待办事项按下回车,将事项添加进列表
给文本框绑定键盘按下事件,通过ASCII值来判断用户是否按下了回车(回车的ASCII值为13);
不能直接在本地存储里更改数据,所以要先获取数据(数组形式),把数组进行更新数据(把最新数据追加给数组),再保存到本地存储;
然后对页面进行重新渲染 更新数据
load(); // 第一步先渲染页面,不然一开始刷新页面时列表不显示
$("#title").on("keydown", function(event) {
if(event.keyCode === 13) {
if($(this).val().trim() !== "") { // trim()去除字符串两侧空格
var data = getDate(); // 获取本地存储数据
// 把数组进行更新数据,把最新数据追加给数组
data.push({title: $(this).val(), done: false});
saveDate(data); // 保存到本地存储
load(); // 渲染加载到页面
$(this).val("");
}
}
})
2. 删除待办事项
先获取本地存储数据;
用attr获取自定义属性index(索引)得到用户点击的第几个事项,通过索引删除数组里对应的那组数据;
将更新过的数组保存到本地存储 再渲染给页面
$("ol, ul").on("click", "a", function() {
var data = getDate(); // 获取本地数据(data是局部变量,不用担心冲突)
var index = $(this).attr("index"); // 用attr获取自定义属性index,得到索引
// splice(index, num)删除数组对象 index为开始删除的位置,num为删除几个
data.splice(index, 1);
saveDate(data);
load();
})
3. 用户点击复选框来选择事项已完成或未完成
获取本地存储数据;
通过复选框的兄弟a的index属性来获取用户点击的事项的索引(index),将第index个数据的done属性值修改为复选框的值;
将更新过的数组保存到本地存储 再渲染给页面
$("ol, ul").on("click", "input", function() {
var data = getDate();
// 利用a获取用户点击的第几个复选框
var index = $(this).siblings("a").attr("index");
// 修改数据:data[索引].属性名 获取固有属性用prop
data[index].done = $(this).prop("checked");
saveDate(data);
load();
})
4. 用户可以通过双击事项进行修改
获取本地存储数据;通过a获取索引index;
在p里创建一个文本框,把p原来的内容赋给文本框,并让其为选中状态;
当文本框失去焦点或用户点击回车,将修改后的内容给当前数组对象的title属性;
将更新过的数组保存到本地存储 再渲染给页面
$("ol, ul").on("dblclick", "p", function() {
var data = getDate();
var index = $(this).siblings("a").attr("index");
// 先将p原来的内容获取过来
var str = $(this).text();
// 创建一个文本框,直接添加到p里
$(this).prepend('<input type="text" />');
// 将原来内容给文本框,并让其为选中(select)状态
var input = $(this).children();
input.val(str);
input.select();
// 当文本框失去焦点,将修改过的文本框的内容给title
$(input).on("blur", function() {
data[index].title = input.val();
saveDate(data);
load();
})
// 按下回车时保存修改
$(input).on("keyup", function(e) {
if(e.keyCode === 13) { // 回车ASCII值为13
// 手动调用点击事件
this.blur();
}
})
})
详细JS代码:
$(function() {
load(); // 第一步先渲染页面,不然一开始刷新页面时列表不显示
// 1、给文本框绑定键盘按下事件
$("#title").on("keydown", function(event) {
if(event.keyCode === 13) {
if($(this).val().trim() !== "") { // trim()去除字符串两侧空格
var data = getDate(); // 获取本地存储数据
// 把数组进行更新数据,把最新数据追加给数组
data.push({title: $(this).val(), done: false});
saveDate(data); // 保存到本地存储
load(); // 渲染加载到页面
$(this).val("");
}
}
})
//2、删除待办事项
$("ol, ul").on("click", "a", function() {
var data = getDate(); // 获取本地数据(data是局部变量,不用担心冲突)
var index = $(this).attr("index"); // 用attr获取自定义属性index,得到索引
// splice(index, num)删除数组对象 index为开始删除的位置,num为删除几个
data.splice(index, 1);
saveDate(data);
load();
})
//3、正在进行和已完成
$("ol, ul").on("click", "input", function() {
var data = getDate();
// 利用a获取用户点击的第几个复选框
var index = $(this).siblings("a").attr("index");
// 修改数据:data[索引].属性名 获取固有属性用prop
data[index].done = $(this).prop("checked");
saveDate(data);
load();
})
// 4、修改事项
$("ol, ul").on("dblclick", "p", function() {
var data = getDate();
var index = $(this).siblings("a").attr("index");
// 先将p原来的内容获取过来
var str = $(this).text();
// 创建一个文本框,直接添加到p里
$(this).prepend('<input type="text" />');
// 将原来内容给文本框,并让其为选中(select)状态
var input = $(this).children();
input.val(str);
input.select();
// 当文本框失去焦点,将修改过的文本框的内容给title
$(input).on("blur", function() {
data[index].title = input.val();
saveDate(data);
load();
})
// 按下回车也可以保存修改
$(input).on("keyup", function(e) {
if(e.keyCode === 13) { // 回车ASCII值为13
// 手动调用点击事件
this.blur();
}
})
})
// 获取本地存储数据
function getDate() {
var data = localStorage.getItem("todolist"); // 将获取到的数据赋给data
if(data !== null) { // 如果本地有数据,则返回数据
return JSON.parse(data); // 本地存储只能存储字符串,所以要获取里边的数据就必须将字符串转换为数组形式返回
} else {
return []; // 如果本地没有数据,则返回一个空数组
}
}
// 保存本地存储数据
function saveDate(data) {
// 用JSON.stringify()将数组转化成字符串保存到本地存储
localStorage.setItem("todolist", JSON.stringify(data));
}
// 渲染加载数据
function load() {
var data = getDate(); // 先获取本地存储数据 // 遍历本地存储数据 将他们添加到列表中
$("ol, ul").empty(); // 遍历之前先清空列表
var doneCount = 0; // 已经完成的个数
var todoCount = 0; // 正在进行的个数
$.each(data, function(i, ele) { // i为索引 ele为遍历对象
// 如果复选框被选中(已完成done: true)添加到ul里,未被选中(未完成done: false)添加到ol里
if(ele.done) {
$("ul").prepend("<li><input type='checkbox' checked='checked' > <p>" + ele.title + "</p> <a href='javascript:;' index=" + i + "></a></li>");
doneCount++; // 每添加一个li,已完成数加一
} else {
$("ol").prepend("<li><input type='checkbox'> <p>" + ele.title + "</p> <a href='javascript:;' index=" + i + "></a></li>");
todoCount++;
}
})
$("#donecount").text(doneCount);
$("#todocount").text(todoCount);
}
})
jQuery模仿ToDoList实现简单的待办事项列表的更多相关文章
- Go For It ,一个灵活的待办事项列表程序
导读 Go For It,是我们开源工具系列中的第十个工具,它将使你在 2019 年更高效,它在 Todo.txt 系统的基础上构建,以帮助你完成更多工作. 每年年初似乎都有疯狂的冲动想提高工作效率. ...
- 使用vue实现简单的待办事项
待办事项 效果图 目录结构 详细代码 AddNew.vue <template> <div> <input v-model="content"/> ...
- Javascript之网页版待办事项
本文使用原生JS实现站点 http://www.todolist.cn/ 的基本功能. 其中页面的HTML布局和CSS样式取用原站,JS部分为自己编写. 效果图 完整代码 HTML.JS部分 < ...
- 模仿ToDoList
1.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
- js仿toDoList(待办事项)练习
JS的一个小练习 展示成果 话不多说 html骨架 <!DOCTYPE html> <html lang="en"> <head> <me ...
- todolist待办事项
使用html/css原生js实现待办事项列表: 支持添加待办事项,删除待办事项,切换待办事项的状态(正在进行,已经完成) 支持对正在进行以及已经完成事项编辑(单击内容即可编辑) 源代码:链接:http ...
- 个人待办事项工具的设计和搭建(IFE前端2015春季 任务3)
这是我几个月之前的项目作品,花了相当的时间去完善.博客人气不高,但拿代码的人不少,所以一直处于保密状态.没有公开代码.但如果对你有帮助,并能提出指导意见的,我将十分感谢. IFE前端2015春季 任务 ...
- 青否云 - 小程序待办事项 jquery开源系统
青否云最新开源系统:小程序待办事项 jquery-demo 青否云 Jquery demo 下载地址:https://github.com/qingful/jquery-demo 官网 http:// ...
- 青否云 - 小程序待办事项vue开源系统
青否云最新开源系统:小程序待办事项 vue-demo 青否云 vue demo 下载地址:https://github.com/qingful/vue-demo 官网 http://cloud.qin ...
随机推荐
- Spring Cloud Alibaba基础教程:Nacos服务发现与配置管理
随着微服务概念的流行,越来越多的公司采用`Spring Cloud`全家桶构建微服务系统,实现业务的快速迭代.`Spring Cloud`提供了快速构建分布式微服务常用组件,包括`Spring Clo ...
- pyspark报错Exception: Java gateway process exited before sending its port number解决方法
1.问题 搭建spark的python环境好后简单使用,源代码如下: 然后就给我丢了一堆错误: 2.解决办法 这里指定一下Java的环境就可以了,添加代码: import os os.environ[ ...
- SpringBoot 整合 Zookeeper 接入Starring微服务平台
背景 最近接的一个项目是基于公司产品Starring做的微服务支付平台,纯后台项目,实现三方支付公司和银行接口来完成用户账户扣款,整合成通用支付接口发布给前端调用. 但是扯蛋了,这边前端什么都不想做, ...
- 为什么服务器突然回复RST——小心网络中的安全设备
RST产生原因 一般情况下导致TCP发送RST报文的原因有如下3种: 1. SYN数据段指定的目的端口处没有接收进程在等待. 2.TCP想放弃一个已经存在的连接. 3.TCP ...
- 基于ManagedDataAccess开发的OracleDBHelpe工具集伸手党的福音
在使用前先加入ManagedDataAccessDLL文件方可使用 添加方法:右键项目.点击管理NuGet程序包,点击浏览,在输入框内输入ManagedDataAccess,再点击安装即可 Oracl ...
- 细说JVM内存模型
细说JVM内存模型 前言 在正式学习 JVM 内存模型之前,先注意以下几个是问题: JVM 内存模型与 JAVA 内存模型不是同一个概念.JVM 内存模型是从运行时数据区的结构的角度描述的概念:而 J ...
- 计算机硬件-CPU
计算机硬件-CPU 冯.诺依曼计算机体系 1.计算机硬件设备由存储器.运算器.控制器.输入设备和输出设备五部分 2.采取二进制形式和指令 3.将程序(数据和指令序列)预先存放在主存储器中,使计算机在工 ...
- kubectl exec 在kubelet中的处理流程
基于kuebrnetes v1.17 简单来说,一个完整的streaming请求如下: 客户端 kubectl exec -i -t ... kube-apiserver 向 Kubelet 发送流式 ...
- 我是怎样测试Java类的线程安全性的
线程安全性是Java等语言/平台中类的一个重要标准,在Java中,我们经常在线程之间共享对象.由于缺乏线程安全性而导致的问题很难调试,因为它们是偶发的,而且几乎不可能有目的地重现.如何测试对象以确保它 ...
- bash中$符号的一般用法
$一般用于获取变量的内容(字符串或数字等),用以构成命令version=$(uname -r).构成字符串echo "my name is $myname".进行算术运算等tota ...