美文网首页
操作DOM的一些有用的综合方法/函数 [二]

操作DOM的一些有用的综合方法/函数 [二]

作者: hyperRect | 来源:发表于2017-05-29 04:20 被阅读0次

* 关于向不同的位置添加元素

1. 向某个元素之前添加元素节点

如下

<div>

         <h1 id="welcome">hi! </h1>

</div>

如果想在h1元素(假设变量名叫nodeH)前且在当前div中添加一个P元素(假设变量名叫nodeP), 可以直接调用 dom的 insertBefore函数。

var nodeH = document.getElementById("welcome");

var nodeP = document.createElement("p");

var pText = document.createTextNode("any text here");

nodeP.appendChild(pText);

insertBefore(nodeP, nodeH);




2. 向某个元素之后添加元素节点

//Dom不提供默认的方法 所以自定义

//获取destEle的父节点, 如果父节点的最后一个节点是当前节点, 则直接在父节点上做appendChild.

//如果不是(即destEle是父节点多个元素节点中的一个,位置不在末尾。此时我们可以在destEle的下一个元素节点前添加这个元素节点)

//保险起见, 检查一下传入参数的nodeType, 需要是元素节点。


function InsertElementAfter(newEle, destEle) {

if (newEle == null) return false;

if (destEle == null) return false;

if (newEle.nodeType != 1) return false;

if (destEle.nodeType != 1) return false;

var parent = destEle.parentNode; //parentNode一定是返回的元素节点 所以不用再检查

if (destEle == parent.lastChild) {

parent.appendChild(newEle);

} else {

parent.insertBefore(newEle, destEle.nextSibling); //由于destEle本身是元素节点, 所以nextSibling也不用担心他是什么节点。直接再同级树层次中添加即可.

}

}

相关文章

  • 操作DOM的一些有用的综合方法/函数 [二]

    * 关于向不同的位置添加元素 1. 向某个元素之前添加元素节点 如下 hi! 如果想在h1元素(假设变量...

  • 操作DOM的一些有用的综合方法/函数 [一]

    GET NEXT ELEMENT 用途:取得某个节点的下一个元素节点(注意,非普通节点。普通节点包括:文本节点, ...

  • JS示例07-选择控制

    一、知识要点 综合使用Dom操作 二、源码参考 三、运行效果

  • jQuery 函数

    Dom操作常用方法 .append()/.prepend() .append()函数用于向每个匹配元素内部的末尾位...

  • JS DOM操作

    DOM及其基础操作DOM:document obiect model 文档对象模型,提供一些属性和方法供我们操作页...

  • DOM操作性能注意

    减少对dom的操作 两个函数做的事一样,但第二个函数做的dom操作明显比第一个少 循环操作前先缓存集合的长度 尽量...

  • 代码创建场景

    方法一 调用菜单命令 EditorApplication中有不少有用的函数 方法二 调用NewScene函数 其中...

  • 【Javascript】DOM操作&事件介绍

    写一个函数,批量操作 css 如何获取 DOM 计算后的样式 使用getComputedStyle方法获取 实现效...

  • js笔记十五之DOM基础-获取元素的方法

    DOM基础 DOM: document object model 文档对象模型,提供一些属性和方法可以让我们去操作...

  • DOM基础

    DOM:document object model 文档对象模型,提供一些属性和方法让我们可以操作DOM元素 获取...

网友评论

      本文标题:操作DOM的一些有用的综合方法/函数 [二]

      本文链接:https://www.haomeiwen.com/subject/kclkfxtx.html