第六节 DOM操作应用
创建、插入和删除元素
创建DOM元素:
createElement(标签名); //创建一个节点
appendChild(节点); //追加一个节点 例如:document.body.appendChild(oDiv); //把div插入到body中,并且位于末尾
举例:为<ul>插入<li>,如上传文件时,即为创建一个DOM元素
var oBtn1=document.getElementById('btn1');
var oUl=document.getElementById('ul1');
var oTxt=document.getElementById('txt1');
//该点击事件相当于:点击第一次,新建一个标签;再点击,就会在其下面创建,一直点击,一直在最下面创建 oBtn.onclick=function () {
var oLi1=document.createElement('li'); //创建li标签
oLi1.innerHTML=oTxt.value; //输出li标签内的内容
oUl.appendChild(oLi1); //父级.appendChild(子节点); 在父级下创建子节点,每次创建的子节点都会往下排,第一次创建的在第一个位置,第二次创建的在第二个位置,依次类推
}; <input id="txt1" type="text"/>
<button id="btn1">创建li</button>
<ul id="ul1"></ul>
插入元素
insertBefore(节点, 原有节点); //在原有的元素前插入节点,即在原有的标签前插入标签
举例:倒序插入<li>
var oBtn2=document.getElementById('btn2'); var oUl=document.getElementById('ul1'); var oTxt=document.getElementById('txt1'); //该点击事件相当于:点击第一次,在最上面新建一个标签,每次点击,都会在最上面创建标签
oBtn2.onclick=function () {
var oLi2=document.createElement('li'); //创建li标签
var aLi=oUl.getElementsByTagName('li');
oLi2.innerHTML=oTxt.value; //输出li标签内的内容
//oUl.insertBefore(oLi2, aLi[0]); //父级.insertBefore(子节点, 在谁之前); 即在第一个位置插入li标签
//注意:上面一句语句在IE浏览器中会报错,因为ul标签内原本什么都没有,所以也就不存在第一个aLi[0],所以报错,此时的解决办法为
if (aLi.length>0){
oUl.insertBefore(oLi2, aLi[0]);
} else {
oUl.appendChild(oLi2);
}
}; <input id="txt1" type="text"/>
<button id="btn2">插入li</button>
<ul id="ul1"></ul>
删除DOM元素:
removeChild(节点); //删除一个节点
举例:删除<li>,如上传文件时,又不想上传了,此时的删除按钮,即为把原来创建的DOM元素,给删除掉
//删除子节点
var aA=document.getElementsByTagName('a');
var oUl3=document.getElementById('ul3'); for (var i=0; i<aA.length; i++){
aA[i].onclick=function () {
// alert(this.parentNode); //返回[object HTMLLIElement],表示<a>的父级为<li>
oUl3.removeChild(this.parentNode); //父级.removeChild()
};
} <ul id="ul3">
<li>abcd<a href="javascript:;">删除</a></li>
<li>efg<a href="javascript:;">删除</a></li>
<li>hijk<a href="javascript:;">删除</a></li>
<li>lmn<a href="javascript:;">删除</a></li>
<li>opq<a href="javascript:;">删除</a></li>
<li>rst<a href="javascript:;">删除</a></li>
</ul>
查找DOM节点:getElementById()、getElementByTagName()
替换DOM节点:replaceChild(新标签, 原标签); //用新标签替换掉原有标签
var oSapn = document.createElement('span'); var oBox = document.getElementById('div'); document.body.replaceChild(oSpan, oBox);
新建、插入、删除综合实例:
<!doctype html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
<style>
.oli{width: 300px; height: 35px; color: #FFFFFF; background-color: #004488; margin-bottom: 1px; padding-left: 20px; line-height: 35px;}
a:link{color: #FFFFFF;}
a:hover{color: #ff0099;}
</style>
<script>
//方法一:这个要用事件代理,比较详细的解法如下: ————网友1
window.onload = function(){
var oul_b1 = document.getElementById('oul_1');
var oBat_a2 = document.getElementById('bat_a2'); oBat_a2.onclick = function(){
var oli_b1 = document.createElement('li');
var text_b2 = document.getElementById('text_a2');
oli_b1.innerHTML = text_b2.value + " <a href='javascript:;'>删除</a>";
oul_b1.appendChild(oli_b1);
//下面的代码是给添加的li加一个class样式
var calss_li = oul_b1.getElementsByTagName('li');
for(var i=0;i<calss_li.length;i++){
//alert(calss_li[1].innerHTML);
calss_li[i].className = 'oli';
}; //下面是删除添加的li,错误示范
// var del_li = document.getElementsByTagName('a');
// alert('dsaf');
// for(var j=0;j<del_li.length;j++){
// // alert(del_li.innerHTML);
// del_li[i].onclick = function(){
// // alert('ada');//测试
// oul_b1.removeChild(this.parentNode); //删除oul_b1的子节点
// };
// }
//错误原因:
//首先,添加完之后可以直接通过querySelector获取刚才添加的a标签
//这里循环是没必要的,而且你的循环会导致之前已经绑定过删除事件的元素又被绑一遍
//虽然没什么其他错,但却是无用功
oli_b1
.querySelector('a')
.addEventListener('click', function(){ //添加一个事件监听器
//然后就是这里的this指的是a标签,他的父节点才是li
//从ul里删除
oul_b1.removeChild(this.parentNode);
}, false);
};
}; //方法二:其实和方法一一样,而且优点是代码简化很多 ————网友2
window.onload=function(){
document.getElementById('bat_a2').onclick = function(){
var val = document.getElementById('text_a2').value;
var text = '<li class="oli">' + val + " <a href='javascript:;'>删除</a></li>";
document.getElementById("oul_1").insertAdjacentHTML('beforeEnd', text);
};
document.getElementById("oul_1").addEventListener("click", function(e) {
if (e.target && e.target.nodeName == "A") {
document.getElementById("oul_1").removeChild(e.target.parentNode);
}
});
};
</script>
</head>
<body>
<input type="text" value="" id="text_a2" />
<input type="button" value="添加LI" id="bat_a2" />
<ul id="oul_1"></ul>
</body>
</html>
getElementById('bat_a2').onclick = function(){ var val = document.getElementById('text_a2').value; var text = '<li class="oli">' + val + " <a href='javascript:;'>删除</a></li>"; document.getElementById("oul_1").insertAdjacentHTML('beforeEnd', text); }; document.getElementById("oul_1").addEventListener("click", function(e) { if (e.target && e.target.nodeName == "A") { document.getElementById("oul_1").removeChild(e.target.parentNode); } }); }; </script> </head> <body> <input type="text" value="" id="text_a2" /> <input type="button" value="添加LI" id="bat_a2" /> <ul id="oul_1"></ul> </body></html>
文档碎片:
文档碎片可以提高DOM操作性能(理论上)
文档碎片的原理
document.createDocumentFragment(); //基本已经不再使用了
需要说明的是:如果是在IE9及以上、FF、Chrome等高级浏览器中运行时,文档碎片其实几乎没有提高什么性能,有时还会拖延性能,但是在IE6-8等低级浏览器中文档碎片确实能相对提高那么一些性能。
window.onload=function(){
var oUl=document.getElementById('ul1');
var oFrag=document.createDocumentFragment(); for (var i=0; i<; i++){ //一次插入10000个标签
var oLi=document.createElement('li');
// oUl.appendChild(oLi); //相当于下面两句oFrag.appendChild(oLi);和oUl.appendChild(oFrag);
oFrag.appendChild(oLi);
}
oUl.appendChild(oFrag);
}; <ul id="ul1"></ul>
第六节 DOM操作应用的更多相关文章
- 迷你MVVM框架 avalonjs 沉思录 第2节 DOM操作的三大问题
jQuery之所以击败Prototype.js,是因为它自一开始就了解这三大问题,并提出完善的解决方案. 第一个问题,DOM什么时候可用.JS不像C那样有一个main函数,里面的逻辑不分主次.但JS是 ...
- 第七节 DOM操作应用-高级
表格应用: 获取:tBodies.tHead.tFoot.rows.cells <!DOCTYPE html> <html lang="en"> <h ...
- 认识JQuery,JQuery的优势、语法、多库冲突、JS原生对象和JQuery对象之间相互转换和DOM操作,常用的方法
(一)认识JQuery JQuery是一个JavaScript库,它通过封装原生的JavaScript函数得到一套定义好的方法 JQuery的主旨:以更少的代码,实现更多的功能 (二)JQue ...
- 第一百一十六节,JavaScript,DOM操作样式
JavaScript,DOM操作样式 一.操作样式 CSS作为(X)HTML的辅助,可以增强页面的显示效果.但不是每个浏览器都能支持最新的CSS能力.CSS的能力和DOM级别密切相关,所以我们有必要检 ...
- 第一百二十六节,JavaScript,XPath操作xml节点
第一百二十六节,JavaScript,XPath操作xml节点 学习要点: 1.IE中的XPath 2.W3C中的XPath 3.XPath跨浏览器兼容 XPath是一种节点查找手段,对比之前使用标准 ...
- 第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表、课程评论表、用户收藏表、用户消息表、用户学习表
第三百七十六节,Django+Xadmin打造上线标准的在线教育平台—创建用户操作app,在models.py文件生成5张表,用户咨询表.课程评论表.用户收藏表.用户消息表.用户学习表 创建名称为ap ...
- 第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型
第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型 Hash操作,redis中Hash在内存中的存储格式如下图: hset(name, key, value)name ...
- ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪
ASP.NET MVC深入浅出(被替换) 一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...
- 第一百一十五节,JavaScript,DOM操作表格
JavaScript,DOM操作表格 学习要点: 1.操作表格 DOM在操作生成HTML上,还是比较简明的.不过,由于浏览器总是存在兼容和陷阱,导致最终的操作就不是那么简单方便了.本章主要了解一下DO ...
随机推荐
- JS 浅谈函数柯里化,不明觉厉
在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术.这个技术由 Christopher ...
- Java-IO基础类回忆
好记性不如烂笔头,就拿Java IO来说吧,这部分的基础类我大学都已经学过一遍了,但是现在忘记的差不多了,所以准备写一篇博客,讲这些东西都回忆一下,并且整理一下. 首先借用网上的一张图: 纵向分为字节 ...
- docker参数注解
# docker --help Usage: docker [OPTIONS] COMMAND [arg...] docker daemon [ --help | ... ] docker [ -h ...
- 用svg绘制圣诞帽
今天是圣诞节,无意中看到csdn博客上面给我的头像带了个圣诞帽,比较好奇,想看看csdn是怎么实现的,果然用的是svg实现,不过代码有点冗长. <html> <body> &l ...
- 线程的条件Condiition
条件Condition相当于给锁造钥匙,但是这钥匙是一次性的.一个线程拿到钥匙进去,出来之后钥匙没有归还,而是没了. 如下代码: from threading import Thread, Condi ...
- 3D Slicer Modify Mouse Event 修改3D Slicer中的鼠标响应事件
在3D Slicer中,我们如果想在自己写的插件中来修改默认的鼠标响应事件的话,就需要先将原有的响应事件链接删除,然后建立自定义的响应事件链接,然后将自己要实现的功能写在响应事件函数中. 比如Slic ...
- python 接口自动化测试(四)cookie&session
掌握了前面几节的的内容,就可以做一些简单的http协议接口的请求发送了,但是这些还不够.HTTP协议是一个无状态的应用层协议,也就是说前后两次请求是没有任何关系的,那如果我们测试的接口之前有相互依赖关 ...
- dedecms (织梦)漏洞&exp整理
[通杀]dedecms plussearch.php 注入漏洞利用方式看结果如果提示Safe Alert: Request Error step 2 !那么直接用下面的exp查看源代码打印帮助1 /p ...
- vue的单向数据流
父级向子组件传递的值, 子组件不能直接修改这个穿过来的值,否则会曝出警告,这就是单项数据流. 如果是引用值,传递的是引用值得地址,而不是值本身,也就是说,子组件里修改这个传过来的值,通常的做法是放到它 ...
- Oracle课程档案,第七天
数据库管理 关闭数据库有4中方式: 1.shutdown modes 关机模式 2.shutdown normal 关机正常 3.shutdown immediate 立即关闭 ★★ 常用命令 4.s ...