DOM中不存在的insertAfter()方法
2016-07-22 16:05
141 查看
DOM提供了名为insertBefore()的方法,这个方法的作用是将一个新元素插入到一个现有元素的前面。
调用语法如下 parentElement(父元素).insertBefore(newElement(新元素), targetElement(目标元素))
知道的人都知道DOM本身没有提供insertAfter方法,但是它确实提供了把一个节点插入到另一个节点之后所需的工具。
我们完全可以利用已有的DOM方法和属性编写一个insertAfter函数。
代码如下:(功能就是将一个新元素插入到现有元素后面)
function insertAfter(newElemnet, targetElement){
var parent = targetElement.parentNode;
if(parent.lastChild == targetElement){
parent.appendChild(newElement);
}else{
parent.insertBefore(newElement, targetElement.nextSibling);
}
}
这个函数用到了以下DOM方法和属性:
parentNode属性
lastChild属性
appendChild方法
insertBefore方法
nextSibling属性
表面上看,函数很复杂,那我们不妨把他分成几个小部分来理解。
首先,这个函数有2个参数:新元素与目标元素。这2个参数通过变量newElement和targetElement被传递到这个函数。
把目标元素的parentNode属性值保留在变量parent里。
检查目标元素是不是parent 的最后一个子元素,即比较parent元素的lastChild属性值与目标元素是否存在“等于”关系。
如果是,就用appendChild方法追加。
如果不是,就把新元素插入到目标元素和目标元素的下一个兄弟元素之间。目标元素的下一个兄弟元素即目标元素的nextSibling属性。然后用insertBefore方法把新元素插入到目标元素的下一个兄弟元素之前。
ps:像这种实用型的函数有必要收录在你的脚本里。
调用语法如下 parentElement(父元素).insertBefore(newElement(新元素), targetElement(目标元素))
知道的人都知道DOM本身没有提供insertAfter方法,但是它确实提供了把一个节点插入到另一个节点之后所需的工具。
我们完全可以利用已有的DOM方法和属性编写一个insertAfter函数。
代码如下:(功能就是将一个新元素插入到现有元素后面)
function insertAfter(newElemnet, targetElement){
var parent = targetElement.parentNode;
if(parent.lastChild == targetElement){
parent.appendChild(newElement);
}else{
parent.insertBefore(newElement, targetElement.nextSibling);
}
}
这个函数用到了以下DOM方法和属性:
parentNode属性
lastChild属性
appendChild方法
insertBefore方法
nextSibling属性
表面上看,函数很复杂,那我们不妨把他分成几个小部分来理解。
首先,这个函数有2个参数:新元素与目标元素。这2个参数通过变量newElement和targetElement被传递到这个函数。
把目标元素的parentNode属性值保留在变量parent里。
检查目标元素是不是parent 的最后一个子元素,即比较parent元素的lastChild属性值与目标元素是否存在“等于”关系。
如果是,就用appendChild方法追加。
如果不是,就把新元素插入到目标元素和目标元素的下一个兄弟元素之间。目标元素的下一个兄弟元素即目标元素的nextSibling属性。然后用insertBefore方法把新元素插入到目标元素的下一个兄弟元素之前。
ps:像这种实用型的函数有必要收录在你的脚本里。
相关文章推荐
- Mootools 1.2教程(2) DOM选择器
- DOM 事件流详解
- Dom在ajax技术中的作用说明
- javascript针对DOM的应用分析(三)
- Dom 是什么的详细说明
- javascript针对DOM的应用分析(五)
- javascript针对DOM的应用实例(一)
- 牛叉的Jquery――Jquery与DOM对象的互相转换及DOM的三种操作
- 在javascript中对于DOM的加强
- Dom与浏览器兼容性说明
- JavaScript DOM学习第一章 W3C DOM简介
- 封装获取dom元素的简单实例
- 《JavaScript DOM 编程艺术》读书笔记之DOM基础
- JQuery包裹DOM节点的方法
- 动态修改DOM 里面的 id 属性的弊端分析
- JavaScript对HTML DOM使用EventListener进行操作
- JavaScript实现获取dom中class的方法
- javascript DOM实用学习资料第1/3页
- 谈谈我对JavaScript DOM事件的理解
- jQuery DOM删除节点操作指南