利用原生js的Dom操作实现简单的ToDoList的效果
效果如下:

前端及js代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>ToDOList</title>
<link rel="stylesheet" href="todolist.css">
</head>
<body style="background-color: #b0b0b0;margin: 0 auto;">
<div class="pg-top">
<label id="l1">ToDoList</label>
<input id="i1" type="text" placeholder="请输入待办项目" />
<input id="i2" type="button" value="确定">
</div>
<div class="pg-body">
<div class="body-middle">
<div>
<div>
<h2 style="color: yellowgreen">未完成</h2>
</div>
<div>
<ul id="u1">
</ul>
</div>
</div>
<div>
<div>
<h2 style="color: greenyellow">已完成</h2>
</div>
<div>
<ul id="u2">
</ul>
</div>
</div>
<div class="middle-bottom">
<button value="清除全部" onclick="clear_all()" >清除全部</button>
</div>
</div>
</div>
<script>
flag = false;
//取值
var msg = document.getElementById('i1');
//点击确定的操作
var sure = document.getElementById('i2');
sure.onclick = function () {
//先判断输入不能为空
if(msg.value === ''){
alert('输入不能为空');
return
}
ul1 = document.getElementById('u1');
ul2 = document.getElementById('u2');
//新建一个li
var li = document.createElement('li');
//往li里添加内容--innerHTML
li.innerHTML = '<label>' + msg.value + '</label>' + '<span><button class="b1">删除</button> <button class="b2">完成</button></span>';
//判断后加入到ul1里面去
var lis = document.getElementsByTagName('li');
ul1.appendChild(li);
//输入完后将输入框的内容清空
msg.value = '';
//点击删除对button b1 进行操作~~
//var as = document.getElementsByTagName('a');
var as = document.getElementsByClassName('b1');
for (var i = 0; i < as.length; i++) {
as[i].onclick = function () {
//this代表as[i]
//判断是哪个ul下的再进行删除操作
if (this.parentNode.parentNode.parentNode === ul1) {
ul1.removeChild(this.parentNode.parentNode);
}
else {
ul2.removeChild(this.parentNode.parentNode);
}
}
}
//点击完成对button b2 进行操作~
var as1 = document.getElementsByClassName('b2');
for (var j = 0; j < as.length; j++) {
as1[j].onclick = function () {
//将完成的li 添加到ul2中
li_u2 = this.parentNode.parentNode;
//console.log(li_u2.firstChild);
//console.log(li_u2.lastChild.firstChild);
//console.log(li_u2.lastChild.firstChild.nextSibling);
//console.log(li_u2.lastChild.lastChild);
//删除完成那个按钮
ll = li_u2.lastChild.lastChild;
li_u2.lastChild.removeChild(ll);
ul2.appendChild(li_u2);
}
}
};
function clear_all() {
var uu1 = document.getElementById('u1');
var uu2 = document.getElementById('u2');
uu1.innerHTML = '';
uu2.innerHTML = '';
}
</script>
</body>
</html>
前端+js
css效果如下:
*{
margin:0;
padding: 0;
}
button{
cursor: pointer;
}
label{
display: block;
}
ul{
list-style-type: none;
}
.pg-top{
height:55px;
width:100%;
position: fixed;
color: white;
background-color: #1d3cb0;
line-height:55px;
/*margin-top: -59px;*/
}
.pg-body{
position: relative;
width:100%;
}
.body-middle{
position: absolute;
left:22%;
right:22%;
margin-top:57px;
width:56%;
margin-left: auto;
margin-right: auto;
background-color: #2b84da;
}
.middle-bottom{
text-align: center;
}
#l1{
position: fixed;
left: 35%;
}
#i1 {
position: fixed;
left:40%;
top:16px;
width:355px;
height:19px;
}
#i2 {
position: fixed;
left:64%;
top:16px;
cursor: pointer;
}
css
利用原生js的Dom操作实现简单的ToDoList的效果的更多相关文章
- 抛开jQuery,拾起原生JS的DOM操作
常用的JS-DOM操作与jQuery的对比 jQuery用多了,还是需要来熟练熟练原生JS的操作,不然写JS都快离不开jQuery了 目录 1. 获取DOM 2. 创建DOM 3. 添加DOM 4. ...
- 原生js封装dom操作库
var utils = (function(window) { var flag = "getComputedStyle" in window; function win(attr ...
- 原生js的dom操作
父节点parentNode 第一个子节点 只会获取到元素节点 firstElementChild ★★★★★ 第一个子节点 (如果有文本节点将会获取到文本节点) firstChild 最 ...
- 整理一下原生js的dom操作
获取元素 getElementById() getElementsByClass() getElementsByTagName getElementsByName node属性 前.后.父.子 pre ...
- js的dom操作(整理)(转)
js的dom操作整理(整理)(转) 一.总结 一句话总结: dom操作有用原生js的dom操作,也可以用对js封装过的jquery等插件来来更加方便的进行dom操作 1.dom是什么? 对于JavaS ...
- js的DOM操作整理(整理)
js的DOM操作整理(整理) 一.总结 一句话总结: dom操作有用原生js的dom操作,也可以用对js封装过的jquery等插件来更加方便的进行dom操作 1.dom是什么? 对于JavaScrip ...
- 原生JS和jQuery操作DOM的区别小结
一.Js原生对象和jQuery实例对象的相互转化: (1).原生JS对象转JQ对象: $(DOM对象); (2). JQ对象转原生JS对象: $(DOM对象).get(index); //注意区分eq ...
- JS的DOM操作 - 你真的了解吗?
摘要 想稍微系统的说说对于DOM的操作,把Javascript和jQuery常用操作DOM的内容归纳成思维导图方便阅读,同时加入性能上的一些问题. 前言 在前端开发的过程中,javascript极为重 ...
- 利用原生JS实现类似浏览器查找高亮功能(转载)
利用原生JS实现类似浏览器查找高亮功能 在完成 Navify 时,增加一个类似浏览器ctrl+f查找并该高亮的功能,在此进行一点总结: 需求 在.content中有许多.box,需要在.box中找出搜 ...
随机推荐
- golang for 循环变量取内存地址
前几天提交的代码进行测试的时候发现变量无法赋值,原始代码如下: for _, asset := range dspInfo.native.Assets { var resAsset protocol. ...
- Singer 学习十二 指南
版本0.3.0 tap是一个应用程序,需要一个配置文件和可选的状态文件作为输入,并产生有序的流记录, 状态和模式信息作为输出. 一个记录是任何类型的JSON编码的数据.tap 状态消息用于保留一个调用 ...
- 13机器学习实战之PCA(2)
PCA——主成分分析 简介 PCA全称Principal Component Analysis,即主成分分析,是一种常用的数据降维方法.它可以通过线性变换将原始数据变换为一组各维度线性无关的表示,以此 ...
- APACHE如何里一个站点绑定多个域名?用ServerAlias servername
APACHE2如何里一个站点绑定多个域名?用ServerAlias以前很笨,要使多个域名指向同一站点总是这样写: <VirtualHost *:80>ServerAdmin i@kuigg ...
- ML(1)——机器学习简述
简述 机器学习是人工智能的一种实现方式:深度学习是一种实现机器学习的技术,或者说是一种特殊的机器学习方法,可以说广义上的机器学习也包括了深度学习,三者的关系如下图所示: 从判别垃圾邮件到无人驾驶技术, ...
- js 数字数组按大小排序
var num = [7,8,6,5,2] //倒序排列 num.sort((a,b)=>{return b-a}) //正序排列 num.sort((a,b)=>{return a-b} ...
- oracle之 如何 dump logfile
这篇文章解释了如何在联机或归档重做日志文件中获取转储. 约束和限制:1.数据库必须安装(或打开).更改系统转储日志文件与任何实例无关,因此不需要为其操作安装数据库.但是,在ALTER SYSTEM D ...
- 简单的user-based协同过滤算法示例代码
#构造一份打分数据集1 users = {"小明": {"中国合伙人": 5.0, "太平轮": 3.0, "荒野猎人" ...
- java 标准输入输出System.in与System.out
System.in System.in 是 InputStream 类的实例对象,该对象的创建是由本地(native)方法完成的. public static final InputStream in ...
- 基于MVC4+EasyUI的Web开发框架形成之旅(5)--框架总体界面介绍
在前面介绍了一些关于最新基于MVC4+EasyUI的Web开发框架文章,虽然Web开发框架的相关技术文章会随着技术的探讨一直写下去,不过这个系列的文章,到这里做一个总结,展示一下整体基于MVC4+Ea ...