js操作DOM元素
创建
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元素的更多相关文章
- JS操作DOM元素属性和方法
Dom元素基本操作方法API,先记录下,方便以后使用. W3C DOM和JavaScript很容易混淆不清.DOM是面向HTML和XML文档的API,为文档提供了结构化表示,并定义了如何通过脚本来访 ...
- Js操作DOM元素及获取浏览器高宽
在JavaScript中,经常会来获取Document文档元素,是 HTML 文档对象模型的英文缩写,Document Object Model for HTML,是基于浏览器编程,HTML DOM ...
- 【面试必备】javascript操作DOM元素
前言 时间过的真快,不知不觉就到年底了.问问自己,这一年你对自己的工作满意吗? 评价标准是什么呢?当然是马云的那两条准则了:钱给到了吗?干的爽吗?如果答案都是no,那么,你准备好跳槽了吗? 为了应对年 ...
- JS/JQuery操作DOM元素笔记
原因 自己目前在搭建一个.NET Core的框架,正在构建权限这块的东西,今天设置权限界面,需要使用JavaScript操作DOM元素,记录一下. 页面大概是酱紫的(我使用的AdminLTE和LayU ...
- 框架操作DOM和原生js操作DOM比较
问题引出 对于Angular和React操作DOM的速度,和原生js操作DOM的速度进行了一个比较: 一个同学做的demo 代码如下: <!DOCTYPE html> <html n ...
- JS操作DOM对象——JS基础知识(四)
一.JavaScript的三个重要组成部分 (1)ECMAScript(欧洲计算机制造商协会) 制定JS的规范 (2)DOM(文档对象模型)重点学习对象 处理网页内容的方法和接口 (3)BOM(浏览器 ...
- js操作DOM对象
js操作DOM对象 (Document Object Model)文档对象模型 nodeType返回值 1:元素节点 2:属性节点 3:文本节点 8:注释节点 9: 文档节点 nodeName 节点 ...
- 原生js操作DOM基础-笔记
原文参考http://mp.weixin.qq.com/s?__biz=MzU3MDA0NTMzMA==&mid=2247485490&idx=1&sn=15197b4b53e ...
- 原生js操作Dom节点:CRUD
知识点,依然会遗忘.我在思考到底是什么原因.想到研究生考试准备的那段岁月,想到知识体系的建立,知识体系分为正向知识体系和逆向知识体系:正向知识体系可以理解为教科书目录,逆向知识体系可以理解考试真题. ...
随机推荐
- 深度学习中batch normalization
目录 1 Batch Normalization笔记 1.1 引包 1.2 构建模型: 1.3 构建训练函数 1.4 结论 Batch Normalization笔记 我们将会用MNIST数 ...
- Spring data mongodb @CreatedBy@LastModifiedBy@CreatedBy@LastModifiedBy SpringSecurityAuditorAware,只记录用户名
要在Spring data mongodb 中使用@CreatedBy@LastModifiedBy@CreatedBy@LastModifiedBy 这四个注解 必须实现 SpringSecuri ...
- 图解MBR分区无损转换GPT分区+UEFI引导安装WIN8.1
确定你的主板支持UEFI引导.1,前期准备,WIN8.1原版系统一份(坛子里很多,自己下载个),U盘2个其中大于4G一个(最好 准备两个U盘)2,大家都知道WIN8系统只支持GPT分区,传统的MBR分 ...
- Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE
1 错误描述 19:15:34 call sp_store_insert(90) Error Code: 1175. You are using safe update mode and you tr ...
- WebService之CXF注解之一(封装类)
Teacher.java: /** * @Title:Teacher.java * @Package:com.you.model * @Description:老师封装类 * @author:Youh ...
- 安装STS报错(一)
安装STS报错 1.具体报错如下 2.报错原因 3.解决办法
- 从1.5K到18K,一个程序员的5年成长之路
原文地址:点击打开链接 168楼朋友批评的很有道理, 虚心接受. 我自己是开始学的时候已经错过了基础课的学习, 现在也是深受其苦的, 面临技术上的瓶颈, 需要花更多的时间补充这些知识. 希望看到此文的 ...
- PyCharm 2017.3 下载与安装
微信公众号:compassblog 欢迎关注.转发,互相学习,共同进步! 有任何问题,请后台留言联系! 1.下载 (1).下载链接: https://www.jetbrains.com/pycharm ...
- Java 第二章 变量、数据类型和运算符
第二章 变量.数据类型和运算符 什么是变量: 变量代表一块内存区域,变量类型不一样,这一块内存的大小也不一样. #在编程语言里面,你可以通过定义变量,向内存里添加数据或者修改内存已有的数据. ...
- Linux之磁盘与文件系统管理
磁盘及文件系统管理详解 [参考文献:马哥视频] 原文:http://blog.csdn.net/u013008795/article/details/51150075 目前市场上主流的磁盘是机械式硬盘 ...