创建

document.createElement()

查找

document.getElementById()   返回对拥有指定 id 的第一个对象的引用。

document.getElementByName()   返回带有指定名称的对象集合。

document.getElementByTagName()   返回带有指定标签名的对象集合。

document.getElementsByClassName()   返回文档中所有指定类名的元素集合。存在兼容性问题,IE6/7/8不支持

这里,重新实现一个函数myGetElementsByClassName,兼容IE6/7/8

        function myGetElementByClassName(classname) {
var ele = [];
if (!document.getElementsByClassName) {
console.log("这是IE6/7/8吧");
var dom = document.all ? document.all : document.getElementsByTagName('*');
for (var i = 0; i < dom.length; i++) {
// if (dom[i].className == classname)
// ele.push(dom[i]);
var reg=new RegExp('\\b'+classname+'\\b','g');
if (reg.test(dom[i].className)) {
ele.push(dom[i]);
}
}
} else {
ele = document.getElementsByClassName(classname);
console.log('不是IE6/7/8 bro');
}
return ele;
}

添加

appendChild(),返回新增的节点

    如果传入到appendChild中的已经是文档的一部分,则把该节点移动到新的位置

还有一种是insertBefore(),这种方法可以插入到指定位置。接收两个参数,第一个是要插入的节点,第二个是作为参照的元素。要插入的节点会成为作为参照的节点的previousSibling。

替换

replaceChild()   接收两个参数,第一个是要插入的节点,第二个是要替换的节点。

在使用replaceChild()插入一个节点时,该节点的关系指针都会从被它替换的节点复制过来。

移除

removeChild()   接收一个参数,要移除的节点。

复制

cloneNode() 用于创建调用这个方法的节点的一个完全相同的副本。

接收一个布尔值参数,如果为true则执行深复制,也就是复制节点以及整个子节点树;如果为false则执行浅复制,也就是只复制节点本身。

复制后返回的节点副本属于文档所有,但是并没有为它指定父节点,需要其他方法来添加到文档中。

移动

移动元素一般是移动有的节点,三种方法:

第一种,使用appendChild()

第二种,使用insertBefore()

第三种,先复制要移动的节点,移除原来这个节点,然后把新得到的节点添加到文档中。

    <div id="div1">11111111</div>
<div id="div2">22222222</div>
<div id="div3">33333333</div>
<script type="text/javascript">
var div1 = document.getElementById('div1');
var div2 = document.getElementById('div2');
var div3 = document.getElementById('div3');
//第一种方法
document.body.appendChild(div1);
//第二种方法
document.body.insertBefore(div1,div3);
//第三种方法
var newNode = div1.cloneNode(true);
document.body.removeChild(div1);
document.body.insertBefore(newNode,div3);
</script>

js操作DOM元素的更多相关文章

  1. JS操作DOM元素属性和方法

    Dom元素基本操作方法API,先记录下,方便以后使用. W3C DOM和JavaScript很容易混淆不清.DOM是面向HTML和XML文档的API,为文档提供了结构化表示,并定义了如何通过脚本来访 ...

  2. Js操作DOM元素及获取浏览器高宽

    在JavaScript中,经常会来获取Document文档元素,是 HTML 文档对象模型的英文缩写,Document Object Model for HTML,是基于浏览器编程,HTML DOM ...

  3. 【面试必备】javascript操作DOM元素

    前言 时间过的真快,不知不觉就到年底了.问问自己,这一年你对自己的工作满意吗? 评价标准是什么呢?当然是马云的那两条准则了:钱给到了吗?干的爽吗?如果答案都是no,那么,你准备好跳槽了吗? 为了应对年 ...

  4. JS/JQuery操作DOM元素笔记

    原因 自己目前在搭建一个.NET Core的框架,正在构建权限这块的东西,今天设置权限界面,需要使用JavaScript操作DOM元素,记录一下. 页面大概是酱紫的(我使用的AdminLTE和LayU ...

  5. 框架操作DOM和原生js操作DOM比较

    问题引出 对于Angular和React操作DOM的速度,和原生js操作DOM的速度进行了一个比较: 一个同学做的demo 代码如下: <!DOCTYPE html> <html n ...

  6. JS操作DOM对象——JS基础知识(四)

    一.JavaScript的三个重要组成部分 (1)ECMAScript(欧洲计算机制造商协会) 制定JS的规范 (2)DOM(文档对象模型)重点学习对象 处理网页内容的方法和接口 (3)BOM(浏览器 ...

  7. js操作DOM对象

    js操作DOM对象  (Document Object Model)文档对象模型 nodeType返回值 1:元素节点 2:属性节点 3:文本节点 8:注释节点 9: 文档节点 nodeName 节点 ...

  8. 原生js操作DOM基础-笔记

    原文参考http://mp.weixin.qq.com/s?__biz=MzU3MDA0NTMzMA==&mid=2247485490&idx=1&sn=15197b4b53e ...

  9. 原生js操作Dom节点:CRUD

    知识点,依然会遗忘.我在思考到底是什么原因.想到研究生考试准备的那段岁月,想到知识体系的建立,知识体系分为正向知识体系和逆向知识体系:正向知识体系可以理解为教科书目录,逆向知识体系可以理解考试真题. ...

随机推荐

  1. Go语言学习_Win10下安装Go开发环境

    关于Go语言有多么值得学习,这里就不做介绍了,既然看了这篇文章,想必是对有学习意向. 这里是在Windows下安装Go环境,去中文社区的下载栏目,https://studygolang.com/dl ...

  2. javascript 函数详解

    一.函数的一些基础概念: 1.js中的函数使用function来声明. 2.关于return: 2.1  函数在执行到return语句后悔立即停止并退出,return后面的代码永远不会得到执行: 2. ...

  3. RestTemplate 支持服务器内302重定向

    Stack Overflow 里找到的代码,可以正常返回服务器302重定向后的响应 final RestTemplate restTemplate = new RestTemplate(); fina ...

  4. FFmpeg-音频和视频应用程序的瑞士军刀

    FFmpeg是一个开源免费跨平台的视频和音频流方案,属于自由软件,采用LGPL或GPL许可证(依据你选择的组件).它提供了录制.转换以及流化音视频的完整解决方案.它包含了非常先进的音频/视频编解码库l ...

  5. linux之x86裁剪移植---grub 识别文件系统

    grub主要作用是找到内核(kernel)与部分核心模块的镜像(initrd,主要是sata硬盘驱动之类的模块),把它们导入内存中运行.kernel与initrd放在文件系统中,因此grub必须有识别 ...

  6. FusionCharts 3D帕累托图

    1.设计3D帕累托图的页面 Pareto3D.html: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN&q ...

  7. FusionCharts ID重复

    1.今天在做项目时,有关FusionCharts柱状图的,调试的过程中,我发现IE浏览器出现FusionCharts ID重复. 具体的消息如下: 消息:#25081843:IECompatibili ...

  8. RFM模型及R语言实现

    每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 一.基本概念 根据美国数据库营销研究所Arth ...

  9. Flex读取txt文件中的内容报错

    Flex读取txt文件中的内容 1.具体错误如下 2.错误原因 读取文件不存在 var file:File = new File(File.applicationDirectory.nativePat ...

  10. 错误代码: 1111 Invalid use of group function

    1.错误描述 1 queries executed, 0 success, 1 errors, 0 warnings 查询:update t_user_info t inner join t_pro_ ...