DOM系统学习-基础
DOM介绍
DOM介绍:
D 网页文档
O 对象,可以调用属性和方法
M 网页文档的树型结构
节点:
DOM将树型结构理解为由节点组成。
节点种类:
元素节点、文本节点、属性节点等
查找元素
获取元素:
getElementById()
getElementsByTagName()
querySeletor()
元素节点属性:
tagName
innerHTML
HTML属性的属性:
id
title
style
className
属性操作:
getAttribute()
setAttribute()
removeAtrribute()
PS:style和onclick有兼容问题,现在都支持自定义属性
DOM节点
node节点属性:
nodeName 节点名称
nodeType 节点类型
nodeValue 节点值,不解析html
层次节点属性:
子节点
childNodes 获取某所有子节点,包括元素节点和文本节点
firstChild 获取第一个节点
lastChild 获取最后一个节点
父兄节点
parentNode 获取父节点
previousSibling 获取上一个同级节点
nextSibling 获取下一个同级节点
ownerDocument 根节点 ele.ownerDocument === document
attributes 属性节点的数组集合
忽略空白节点的方法:
忽略:
1
2
3
4
5
6
7
8
9
10
11
12
|
function filterSpaceNode(nodes) { var ret = []; //新数组 for ( var i = 0; i < nodes.length; i++) { //如果识别到空白文本节点,就不添加数组 if (nodes[i].nodeType == 3 && /^\s+$/.test(nodes[i].nodeValue)) { continue ; } //把每次的元素节点,添加到数组里 ret.push(nodes[i]); } return ret; } |
移除:
1
2
3
4
5
6
7
8
9
|
function removeWhiteNode(element) { var nodes = element.childNodes; for ( var i = 0; i < nodes.length; i++) { if (nodes[i].nodeType === 3 && /^\s+$/.test(nodes[i].nodeValue)) { nodes[i].parentNode.removeChild(nodes[i]); } } return element; } |
节点操作
创建节点:
document.createElement() 创建一个元素节点
document.createTextNode(txt) 创建文本节点
插入节点:
ele.appendChild(newChild) 将新节点添加到某个节点的子节点末尾
insertBefore(newChild,refChild) 指点节点前面插入新节点
insertAfter() 需要自定义
1
2
3
4
5
6
7
8
9
10
11
|
function insertAfter(newElement, targetElement) { //得到父节点 var parent = targetElement.parentNode; //如果最后一个子节点是当前元素,那么直接添加即可 if (parent.lastChild === targetElement) { parent.appendChild(newElement); } else { //否则,在当前节点的下一个节点之前添加 parent.insertBefore(newElement, targetElement.nextSibling); } } |
替换复制移除:
replaceChild(newChild,refChild) 替换节点,必须是某元素的子节点
cloneChild(deep) 克隆节点
removeChild(oldChild) 移除节点
DOM系统学习-基础的更多相关文章
- DOM系统学习-进阶
DOM类型 Node类型: 常用类型: 元素节点 ELEMENT_NODE 属性节点 ATTRIBUTE_NODE 文本节点 TEX ...
- DOM系统学习-表格、样式和元素大小
操作表格 属性: caption 标题元素 tHead 表头元素 tFoot 表尾元素 tBodies 主体元素集合,通过下标取 row 行元素集合,通过下标取 方法 ...
- 深入浅出DOM基础——《DOM探索之基础详解篇》学习笔记
来源于:https://github.com/jawil/blog/issues/9 之前通过深入学习DOM的相关知识,看了慕课网DOM探索之基础详解篇这个视频(在最近看第三遍的时候,准备记录一点东西 ...
- 零基础如何系统学习Java Web
零基础如何系统学习Java Web? 我来给你说一说 你要下决心,我要转行做开发,这样你才能学成. 你要会打字,我公司原来有一个程序员,打字都是两个手一指禅,身为程序员你一指禅怎么写出的代码,半个 ...
- Unity3D 装备系统学习Inventory Pro 2.1.2 基础篇
前言 前一篇 Unity3D 装备系统学习Inventory Pro 2.1.2 总结 基本泛泛的对于Inventory Pro 这个插件进行了讲解,主要是想提炼下通用装备系统结构和类体系.前两天又读 ...
- Linux学习之六-Linux系统的基础优化
Linux系统的基础优化 何谓'优化'.顾名思义,优化就是采取某些措施使某个东西或者某事物变得更加优异,出色.对于Linux而言,在初期安装好系统之后,也需要对其进行一定的基础优化,可分为安全上的优化 ...
- 现代3D图形编程学习-基础简介(2) (译)
本书系列 现代3D图形编程学习 基础简介(2) 图形和渲染 接下去的内容对渲染的过程进行粗略介绍.遇到的部分内容不是很明白也没有关系,在接下去的章节中,会被具体阐述. 你在电脑屏幕上看到的任何东西,包 ...
- 001 今天开始系统学习C#
2016-01-16 之前只是大概了解过c#语言,感觉掌握不牢靠.现在开始系统学习C#.现以该博客作为学习笔记,方便后续查看.C# 目标:系统掌握c#知识 时间:30天 范围:C#基础,Winform ...
- JavaScript学习基础部分
JavaScript学习基础 一.简介 1.JavaScript 是因特网上最流行的脚本语言,并且可在所有主要的浏览器中运行,比方说 Internet Explorer. Mozilla.Firefo ...
随机推荐
- atom插件之less-autocompile
less-autocompile package Auto compile LESS file on save. Add the parameters on the first line of the ...
- Android使用adb命令查看CPU信息
Android中使用JNI编程的时候会需要编译出不同的SO文件,以供适配不同的机型. 例如: 由此需要查看不同机型的CPU信息. 使用ADB命令查看CPU信息命令如下: 1. adb shell 2. ...
- 【bzoj2044】三维导弹拦截 dp+二分图最大匹配
题目描述 n个物品,第i个位置有ai.bi.ci三种属性.每次可以选出满足$\ a_{p_i}<a_{p_{i+1}}\ ,\ b_{p_i}<b_{p_{i+1}}\ ,\ c_{p_i ...
- [洛谷P4588][TJOI2018]数学计算
题目大意:有一个数$x$和取模的数$mod$,初始为$1$,有两个操作: $m:x=x\times m$并输出$x\% mod$ $pos:x=x/第pos次操作乘的数$(保证合法),并输出$x\%m ...
- [洛谷P3807]【模板】卢卡斯定理
题目大意:给你$n,m,p(p \in \rm prime)$,求出$C_{n + m}^m\bmod p(可能p\leqslant n,m)$ 题解:卢卡斯$Lucas$定理,$C_B^A\bmod ...
- POJ3717 Decrypt the Dragon Scroll
Description Those who have see the film of "Kong Fu Panda" must be impressive when Po open ...
- 仿今日头条按钮loading效果
效果 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...
- 泛型与非泛型集合类的区别及使用例程,包括ArrayList,Hashtable,List<T>,Dictionary<Tkey,Tvalue>,SortedList<Tkey,Tvalue>,Queue<T>,Stack<T>等
泛型与非泛型集合类在C#程序中是非常重要的一个基础概念,这里列一个表来进行对比: 非泛型集合类 泛型集合类 描述 ArrayList List<T> 表示具有动态大小的对象数组 Hasht ...
- 《R语言实战》读书笔记--第三章 图形初阶(二)
3.4添加文本.自定义坐标轴和图例 很多作图函数可以设置坐标轴和文本标注.比如标题.副标题.坐标轴标签.坐标轴范围等.需要注意的是并不是所有的绘图函数都有上述的参数,需要进行验证.可以将一些默认的参数 ...
- Oracle SQL 疑难解析读书笔记(一 基础)
1.在语句中找到和消除空值 select first_name,last_name from hr.employees where commission_pct is null is null 和 i ...