Dom 获取、Dom动态创建节点
一、Dom获取
1、全称:Document Object Model 文档对象模型
2、我们常用的节点类型
元素(标签)节点、文本节点、属性节点(也就是标签里的属性)、
3、document有个属性叫nodeType返回的是数字
1:代表元素节点
2:代表属性节点
3:代表文本节点
4、节点的获取
元素节点的获取方法
Document.getElementById()
Document.getElementsByClassName()
Document.getElementsByTagName()
Document.querySelector()
Document.querySelectorAll()
属性节点的获取方法
元素 . getAttribute("属性名") 获取属性值的方法
元素 . attribuites 获取元素身上所有属性构成的集合(数组)
元素 . attribute [ 索引 ] . value 获取元素里面的值
元素 . setAttribute("属性名","属性值") 给元素设置属性和属性值
元素 . remove("属性") 删除元素
文本节点没有获取的方法,没有意义
5、获取元素的子节点
元素 . childNodes 这个属性有兼容性,标准浏览器回获取文本节点,而低版本的浏览器不会,所以建议children属性
获取单个子节点:具有兼容问题
获取第一个子节点:
标准下:元素 . firstElementchild
非标准下:元素 . firstchild
获取最后一个子节点:
标准下:元素 .lastElementchild
非标准下:元素 . lastchild
获取上一个兄弟节点:
标准下:元素 . previousElementsibling
非标准下:元素 . previoussibling
获取上一个兄弟节点:
标准下:元素 . nextElementchild
非标准下:元素 . nextchild
解决兼容性问题:
拿获取第一个子节点为列:
var list=document . getElementById("list")
var ss=list . firstElementchild || list . firstchild
6、获取父节点
元素 . parentNode 没有兼容性
二、Dom 动态创建节点
1、生成节点的方法:
document . createElement("div")
2、插入节点的方法:
父节点 . appendChild("新节点")
3、在指定的位置插入节点
父节点 . inserBefore(新节点,谁的前面) 将元素插入指定节点的前面
4、删除节点
父节点 . removechild()
三、拓展
字符串中的拼接和Dom创建都是渲染的方试
字符串:
优点:简单,可以处理数据,层次感比较强
缺点:字符串拼接会影响到原来子元素的事件
Dom创建:
优点:是一个独立的个体,不会影响到原来的元素
缺点:处理数据量过大会比较麻烦,会造成Dom回流
Dom回流:
页面渲染时,我们对html结构简单的增删查改时,浏览器会对所有的dom重新排序,这就是Dom回流,严重影响浏览器的性能
提升页面性能优化:
1、多采用雪碧图
2、阻止超链接的默认行为
3、减少DOM回流
4、减少向服务器请求次数
Dom 获取、Dom动态创建节点的更多相关文章
- 11-15 dom 动态创建节点
1.生成节点的方法 document.createElement(“div”) 2.插入节点的方法 父元素.appendChild(新节点) 在父节点中的子节点后面插入新的节点 3.在指定的位置 ...
- delphi dom动态创建节点方法
在一次测试demo中 需要动态的创建xml节点并添加,实现方法如下: var NewItem:IXMLDOMElement; NewItem:=ConfigDoc.createElement('ite ...
- HTML中javascript使用dom获取dom节点范例
<!-- HTML结构 --> <div id="test-div"> <div class="c-red"> <p ...
- js···DOM2动态创建节点
1.生成节点的方法 document.createElement(“div”) 2.插入节点的方法 父元素.appendChild(新节点) 在父节点中的子节点后面插入新的节点 3.在指定的位置 ...
- jquery动态创建节点
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- DOM创建节点
1.DOM--document object model 常用的节点类型: 元素节点:(标签) 属性节点:(标签里的属性) 文本节点:(文本节点) 2,document有个属性叫nodetype,返回 ...
- 关于document的节点;用Dom2创建节点;
一.关于节点 1.节点树状图 document>documentElement>body>tagName 2.节点类型 元素节点(标签).文本节点(文本).属性节点(标签属性) 3. ...
- FineUIMvc随笔 - 动态创建表格列
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. 用户需求 用户希望实现动态创建表格列,在 WebForms 中,我们通过在 Page_Init 中创建列来实现: 但是在 MVC ...
- FineUIMvc随笔(1)动态创建表格列
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版. <FineUIMvc随笔>目录 FineUIMvc随笔(1)动态创建表格列 FineUIMvc随笔(2)怎样在控件中 ...
随机推荐
- MYSQL进阶学习笔记十:MySQL慢查询!(视频序号:进阶_23-24)
知识点十一:MySQL 慢查询的应用(23) 一.慢查询定义 MySQL记录下查询超过指定时间的语句,我们将超过指定时间的SQL语句查询称为慢查询. 查看时间限制 show variables lik ...
- [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)]
我自己写的第一个 Silverlight 2.0 程序 [Silverlight 2.0 控制物体绕圆弧运行(C#初探篇)] 程序运行时:小地球将绕着圆形轨迹做圆周运动. ...
- lucene Index Store TermVector 说明
最新的lucene 3.0的field是这样的: Field options for indexingIndex.ANALYZED – use the analyzer to break the Fi ...
- 四叉树 bnuoj
点击打开题目链接 建树+广搜一棵树:最下面有更短代码(很巧妙). #include<iostream> #include<stdio.h> #include<queue& ...
- 【CAIOJ1177】 子串是否出现
[题目链接] 点击打开链接 [算法] KMP [代码] #include<bits/stdc++.h> using namespace std; #define MAXA 1000010 ...
- 洛谷P1113杂物——DP
题目:https://www.luogu.org/problemnew/show/P1113 每个任务的时间就是准备工作中完成最晚的那个的时间再加上自己的时间. 代码如下: #include<i ...
- bzoj3998
后缀自动机+dp 想了挺长时间 后缀自动机的状态图是一个dag,从root走到一个点的路径数代表了这个状态包含的子串,我们先预处理出来每个节点向后走能够形成多少子串,注意这里不是直接在parent树上 ...
- HDU 5883 The Best Path (欧拉路或者欧拉回路)
题意: n 个点 m 条无向边的图,找一个欧拉通路/回路使得这个路径所有结点的异或值最大. 析:由欧拉路性质,奇度点数量为0或2.一个节点被进一次出一次,度减2,产生一次贡献,因此节点 i 的贡献为 ...
- 分析express-pjax
先来看见express-pjax的源代码 module.exports = function() { return function(req, res, next) { if (req.header( ...
- 51Nod 1649 齐头并进
#include <iostream> #include <algorithm> #include <cstring> //两遍迪杰斯特拉 #define INF ...