本文主要讲解DOM常用的CURD操作,appendChild(往后追加节点),insertBefore(往前追加节点),removeChild(移除节点),replaceChild(替换节点),cloneNode(克隆节点)的语法与实战应用

一、appendChild: 向元素的内部最后面增加一个节点,或者移动一个现有的节点到元素的内部最后面

用法:

someNode.appendChild( newNode )

someNode通常为元素的父节点

返回值:

返回新增加的节点

     <input type="text" name="" id="txt">
<input type="button" value="添加" id="add">
<ul id="box"></ul>
<script>
var oBtn = document.querySelector("#add");
var oTxt = document.querySelector("#txt");
var oBox = document.querySelector("#box");
oBtn.onclick = function () {
var oLi = document.createElement( "li" );
oLi.innerHTML = oTxt.value;
var returnNode = oBox.appendChild( oLi );
console.log( returnNode === oLi ); //true
console.log( returnNode === oBox.lastChild );//true
}
</script>

上例,把文本框的内容当做一个新节点,添加在id为box的元素的最后面,返回值returnNode就是新增加的节点,

所以 第12行和第13行的返回值为ture, lastChild表示元素的最后一个子节点

如果appendChild后面的参数是文档现有的节点,那么表示把当前节点移动到父元素的最后面

 <input type="button" value="移动" id="btn">
<ul id="box">
<li><a href="javascript:;">王朝</a></li>
<li><a href="javascript:;">马汉</a></li>
<li><a href="javascript:;">张龙</a></li>
<li><a href="javascript:;">赵虎</a></li>
<li><a href="javascript:;">ghostwu</a></li>
</ul>
<script>
var oBtn = document.getElementById("btn");
var oBox = document.getElementById("box");
oBtn.onclick = function () {
var firstChild = oBox.firstElementChild || oBox.firstChild;
var lastChild = oBox.lastElementChild || oBox.lastChild;
var returnNode = oBox.appendChild( firstChild );
firstChild = oBox.firstElementChild || oBox.firstChild;
lastChild = oBox.lastElementChild || oBox.lastChild;
console.log( returnNode === firstChild ); //false
console.log( returnNode === lastChild ); //true
}
</script>

上例,每次点击按钮,把第一个节点移动到最后,所以在第18行为false, 因为移动之后,他就不是第一个节点了,而变成最后一个节点,所以第19行比较结果为true

二、insertBefore:向一个元素前面追加节点

用法:

someNode.insertBefore( newNode, referNode );

第一个参数: newNode,需要插入的节点

第二个参数: referNode, 参考节点,即:newNode会插入到这个参考节点的前面,

注意:如果第二个参数为null, 效果等同于someNode.appendChild( newNode )

返回值:

新插入的节点

     <input type="text" id="txt">
<input type="button" value="添加" id="add">
<ul id="box"></ul>
<script>
var G = function ( id ){ return document.getElementById( id ) };
var GG = function ( id, tag ){ return G(id).getElementsByTagName(tag) };
var oTxt = G( "txt" ),
oBox = G( "box" ),
oAdd = G( "add" )
aLi = GG( 'box', 'li' );
oAdd.onclick = function(){
var oLi = document.createElement("li");
oLi.innerHTML = oTxt.value,
returnNode = null;
//等价于oBox.appendChild( oLi )
// oBox.insertBefore( oLi, null );
// oBox.appendChild( oLi );
if( aLi[0] ) {
returnNode = oBox.insertBefore( oLi, aLi[0] );
}else {
returnNode = oBox.insertBefore( oLi, null );
}
console.log( returnNode );
}
</script>

 三、removeChild: 移除一个节点

someNode.removeChild( node )

someNode通常为父元素,node就是父元素下面的一个元素

返回值: 当前被移除的元素

 <input type="text" name="" id="txt">
<input type="button" value="移除" id="remove">
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
<script>
var oRemove = document.querySelector( "#remove" );
var oUl = document.querySelector( "ul" );
oRemove.onclick = function(){
var n = parseInt( document.querySelector("#txt").value );
var returnNode = oUl.removeChild( oUl.children[n] );
console.log( returnNode );
}
</script>

上例,在输入框中, 输入需要移除的子节点的索引,即可完成移除节点操作.

四、replaceChild: 用新节点去替换已经存在的节点

用法

someNode.replaceChild( newNode, node )

第一个参数:新节点

第二个参数: 被替换的节点

返回值: 返回当前被替换的子节点

下例,有点小复杂,用了节点缓存(设计模式中的享元模式)提高替换节点的性能,虽然只有8个节点,如果是上万个节点,会有明显的提高.

 <input type="button" value="替换" id="replace">
<br>
<span>第1个元素</span>
<span>第2个元素</span>
<span>第3个元素</span>
<span>第4个元素</span>
<span>第5个元素</span>
<span>第6个元素</span>
<span>第7个元素</span>
<span>第8个元素</span>
<script>
var oReplace = document.querySelector("#replace"),
aSpan = document.querySelectorAll("span"),
page = 0, //当前页
perPage = 4, //每次替换4个
total = Math.ceil(aSpan.length / perPage); //总页数 var cache = (function () {
var aEle = [];
var create = function () {
var oDiv = document.createElement("div");
aEle.push(oDiv);
return oDiv;
};
return {
getDiv: function () {
if (aEle.length < 4) {
console.log(1);
return create();
} else {
console.log(2);
var oDiv = aEle.shift();
aEle.push(oDiv);
return oDiv;
}
}
};
})();
var aCacheSpan = [];
oReplace.onclick = function () {
var oDiv = null;
page++;
if (page < 3) {
if (aCacheSpan.length > 0) {
var oBox = document.querySelector('div');
for (var i = 0, len = aCacheSpan.length; i < len; i++) {
document.body.insertBefore(aCacheSpan[i], oBox);
}
aCacheSpan = [];
}
for (var i = (page - 1) * perPage; i < (page - 1) * perPage + perPage; i++) {
console.log(aSpan[i].innerHTML);
oDiv = cache.getDiv();
oDiv.innerHTML = aSpan[i].innerHTML;
aCacheSpan.push(document.body.replaceChild(oDiv, aSpan[i]));
}
}
}
</script>

 五、cloneNode: 复制一个节点

用法:

someNode.clone( bool值 )

参数有两种情况:
如果为true: 代表深拷贝: 即复制当前节点和他下面的所有子节点,如果存在行间事件,也会被复制

如果为false: 代表浅拷贝:即复制当前节点,不会复制他下面的子节点

返回值:返回当前被复制的元素

 <input type="button" value="深拷贝" id="btn1">
<input type="button" value="浅拷贝" id="btn2">
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
</ul>
<script>
var oBtn1 = document.querySelector("#btn1");
var oBtn2 = document.querySelector("#btn2");
var oUl = document.querySelector( "ul" );
oBtn1.onclick = function () {
var aNode = oUl.cloneNode( true );
console.log( aNode );
}
oBtn2.onclick = function () {
var aNode = oUl.cloneNode( false );
console.log( aNode );
}
</script>

[js高手之路] dom常用API【appendChild,insertBefore,removeChild,replaceChild,cloneNode】详解与应用的更多相关文章

  1. [js高手之路] dom常用节点属性兼容性详解与应用

    一.每个DOM节点都有一个nodeType属性,表示节点类型, NodeType一共有12种类型,我们可以通过遍历内置的Node构造函数获取 window.onload = function(){ v ...

  2. [js高手之路] html5 canvas系列教程 - 掌握画直线图形的常用API

    我们接着上文[js高手之路] html5 canvase系列教程 - 认识canvas以及基本使用方法继续. 一.直线的绘制 cxt.moveTo( x1, y1 ): 将画笔移动到x1, y1这个点 ...

  3. JS操作DOM常用API总结

    <JS高程>中的DOM部分写的有些繁琐,还没勇气整理,直到看到了这篇博文 Javascript操作DOM常用API总结,顿时有了一种居高临下,一览全局的感觉.不过有时间还是得自己把书里面的 ...

  4. [js高手之路] html5 canvas动画教程 - 实时获取鼠标的当前坐标

    有了前面的canvas基础之后,现在开始就精彩了,后面写的canvas教程都是属于综合应用,前面已经写了常用的canvas基础知识,参考链接如下: [js高手之路] html5 canvas系列教程 ...

  5. [js高手之路]设计模式系列课程-组合模式+寄生组合继承实战新闻列表

    所谓组合模式,就是把一堆结构分解出来,组成在一起,现实中很多这样的例子,如: 1.肯德基套餐就是一种组合模式, 比如鸡腿堡套餐,一般是是由一个鸡腿堡,一包薯条,一杯可乐等组成的 2.组装的台式机同理, ...

  6. [js高手之路]Node.js+jade+mongodb+mongoose实现爬虫分离入库与生成静态文件

    接着这篇文章[js高手之路]Node.js+jade抓取博客所有文章生成静态html文件继续,在这篇文章中实现了采集与静态文件的生成,在实际的采集项目中, 应该是先入库再选择性的生成静态文件.那么我选 ...

  7. [js高手之路] html5 canvas系列教程 - 图片操作(drawImage,clip,createPattern)

    接着上文[js高手之路] html5 canvas系列教程 - 文本样式(strokeText,fillText,measureText,textAlign,textBaseline)继续,本文介绍的 ...

  8. 【repost】Javascript操作DOM常用API总结

    Javascript操作DOM常用API总结 文本整理了javascript操作DOM的一些常用的api,根据其作用整理成为创建,修改,查询等多种类型的api,主要用于复习基础知识,加深对原生js的认 ...

  9. [js高手之路]深入浅出webpack教程系列6-插件使用之html-webpack-plugin配置(下)

    上文我们对html-webpack-plugin的实例htmlWebpackPlugin进行了遍历分析,讲解了几个常用属性( inject, minify )以及自定义属性的添加,本文,我们继续深入他 ...

随机推荐

  1. JavaScript 第一课

    今天进入到了js的阶段,了解到了JavaScript是一个很重要的阶段,所以要好好的理清每一个知识点 JavaScript的使用:   在<head>标签里应用<script> ...

  2. Python实现浏览器自动化操作

    Python实现浏览器自动化操作 (2012-08-02 17:35:43) 转载▼     最近在研究网站自动登录的问题,涉及到需要实现浏览器自动化操作,网上有不少介绍,例如使用pamie,但是只是 ...

  3. nodejs 实践:express 最佳实践 (一)

    express 最佳实践 (一) 最近,一直在使用 nodejs 做项目,对 nodejs 开发可以说深有体会. 先说说 nodejs 在业务中的脚色,, 在 web同构 方面, nodejs 的优势 ...

  4. jQuery知识点整合

    一.jQuery介绍 jQuery是一个函数库,一个js文件,页面用script标签引入js文件就可以使用 <script type="text/javascript" sr ...

  5. 【MySQL故障处理】 Seconds_Behind_Master= NULL Error_code: 1197

    版本:mysql 5.6.32**错误描述:**```Error_code: 1197Last_Error: Worker 3 failed executing transaction '352aa3 ...

  6. 51nod_1836:战忽局的手段(期望)

    题目链接 公式比较好推 精度好难搞啊@_@ 下面记笔记@_@ **** long double用%LF输出 **** __float128 精度比 long double 高(可以在中间运算时使用,输 ...

  7. GitHub转华为软件开发云详细教程

    一.复制GitHub的代码库地址 首先,打开Github网页,找到要迁移的代码仓库地址,如下: 点击Clone or Download,出现以下界面 点击Copy toclipboard(复制到粘贴板 ...

  8. C++第四篇--重载_指针_引用

    C++第四篇--重载_指针_引用 1. 基础知识 重载:函数名相同,根据参数不同(类型.数量.顺序不同)调用同名函数 指针和引用:引用就是别名,引用时必须初始化,引用你定义的变量. int a; in ...

  9. hbase集群导入csv文件

    小数据文件导入: 样例 hbase  org.apache.hadoop.hbase.mapreduce.ImportTsv  -Dimporttsv.separator="," ...

  10. strtok函数 分类: c++ 2014-11-02 15:24 214人阅读 评论(0) 收藏

    strtok函数是cstring文件中的函数 strtok函数是cstring文件中的函数 其功能是截断字符串 原型为:char *strtok(char s[],const char *delin) ...