1. 什么是DOM: Document Object Model

专门操作网页内容的API

js=ES+DOM+BOM

DOM是由W3C指定的API标准

为什么: 为了统一各个浏览器操作网页内容的API标准

用DOM标准操作网页内容,几乎100%兼容

能做什么: 增删改查,事件绑定

2. DOM Tree:

什么是: 内存中保存所有网页内容的树型结构

为什么: 树型结构是最灵活,最直观保存层级关系的结构

何时: 当浏览器读到一个网页文件时,会从上到下顺序读取文件中的内容(元素,属性,文本)

并在内存中,构建树结构,保存网页中所有内容

DOM只有唯一的一个根节点: document 指代整个网页

网页中所有内容都是DOM树上的节点对象

节点对象的公共父类型: Node

三个公共属性:

.nodeType: 节点类型:

值是一个数字:

1   element

2   attribute

3   text

9   document

何时: 区分节点的类型时

问题: 无法进一步区分元素的名称

.nodeName: 节点名

值是一个字符串

element  全大写标签名

attribute  属性名

text      #text

document  #document

何时: 只要精确区分元素的名称时

.nodeValue: 节点值

几乎不用:

element  null

attribute   属性值

text      文本内容

document  null

3. 查找: 4种:

1. 不需要查找就可直接获得的元素: 4种:

document.documentElement     html

document.head                head

document.body                body

document.forms[i/id]            form

2. 按节点间关系查找:

节点树: 包含所有网页内容的树结果

2大类:

1. 父子关系: 4个

.parentNode  父节点  返回一个节点

.childNodes   直接子节点  返回多个节点的类数组对象

.firstChild     第一个直接子节点

.lastChild     最后一个直接子节点

2. 兄弟关系:

.previousSibling 前一个兄弟

.nextSibling 后一个兄弟

问题: 受看不见的空字符的干扰

解决: 元素树:

元素树: 仅包含元素节点的树结构

2大类:

1. 父子关系: 4个

.parentElement  父元素

.children   直接子元素

.firstElementChild     第一个直接子元素

.lastElementChild     最后一个直接子元素

2. 兄弟关系:

.previousElementSibling 前一个兄弟元素

.nextElementSibling 后一个兄弟元素

说明: 元素树不是一棵新树,只是节点树的子集

元素树有兼容性问题

问题: 只能在先获得一个节点对象的情况下,找周围附近的节点

解决: 用HTML特征查找

3. 按HTML特征查找: 4种:

1. 按id查找1个元素

var elem=document.getElementById(id);

强调: ById只能用document调用

2. 按标签名查找多个元素:

var elems=parent.getElementsByTagName(标签名)

强调:可用任意父元素调用

不仅查找直接子元素,且在所有后代中查找

3. 按name属性查找多个元素:

var elems=document.getElementsByName(name)

强调: 只能用document调用

4. 按class查找多个元素:

var elems=parent.getElementsByClassName(class)

强调: 可在任意父元素上调用

只要一个class与之匹配,就选择该元素

动态集合(live collection):

什么是: 不实际存储数据,每次访问集合,都重新查找DOM树。

为什么: 首次查找不必准备完整数据,就可快速返回

缺点: 如果反复访问集合,会导致反复查找DOM树

何时: childNodes, children, getElementsByXX()都返回动态集合

不好的遍历: for(var i=0;i<children.length;i++)

好的遍历: for(var i=0,len=children.length;i<len;i++)

DOM-DOMTree-查找的更多相关文章

  1. DOM元素查找

    一.DOM是document的缩写,他是操作html文档的方法 二.常用查找元素的方法 直接 1.document.getElementById('标签的id')   在html中标签的id是不允许重 ...

  2. DOM遍历查找结点

    一.遍历API(2个) 1.深度优先原则遍历NodeIterator 节点迭代器 创建遍历API对象: var iterator=document.createNodeIterator(开始的父节点对 ...

  3. JS操作DOM节点查找

    JS中常用的DOM操作事件,包括有节点查找,键盘鼠标事件等等,本文内容介绍DOM的节点查找. <script> window.onload = function(){ //children ...

  4. DOM的查找,新增,删除操作

    查找 1. document.getElementById()  通过ID获取元素,由于ID唯一,所以获取的是一个元素 2. document.getElementsByTagName() 通过标签名 ...

  5. DOM的查找与操作

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  6. dom node 查找父级parentNode

    var o = document.querySelectorAll("a[href='baidu.com']"); var p = o[o.length-1];console.lo ...

  7. (二)Jsoup 查找 DOM 元素

    第一节: Jsoup 查找 DOM 元素 getElementById(String id) 根据 id 来查询 DOM getElementsByTag(String tagName) 根据 tag ...

  8. DOM节点的创建、插入、删除、查找、替换

    在前端开发中,js与html联系最紧密的莫过于对DOM的操作了,本文为大家分享一些DOM节点的基本操作. 一.创建DOM节点 使用的命令是 var oDiv = document.createElem ...

  9. dom 操作

    1.dom 的查找 (1)根据id 查找 var object = document.getElementById("id 值"): (2)根据 name 查找:返回 dom 对象 ...

  10. jQuery学习笔记(二)jQuery中DOM操作

    目录 DOM操作分类 jQuery中的各种DOM操作 查找节点 创建节点 删除节点 复制节点 替换节点 包裹节点 属性操作 样式操作 对HTML.文本和值的操作 遍历节点 CSS-DOM操作 小结 本 ...

随机推荐

  1. mysql5.6 基于Binlog ROW记录方式进行数据恢复(无备份)

    数据库配置注意事项 /etc/my.cnf 必须要开户binlog支持,字符集要求 是utf8 binlog类型为row server-id=121 log_bin=/home/mysqllog bi ...

  2. 数位dp poj1850

    题目链接:https://vjudge.net/problem/POJ-1850 这题我用的是数位dp,刚刚看了一下别人用排列组合,我脑子不行,想不出来. 在这题里面我把a看成1,其他的依次递增,如果 ...

  3. Centos7在虚拟机中扩展磁盘空间

    说明 情况:已经在VirtualBox虚拟机创建了一个磁盘并已经装好了系统,发现磁盘空间太小,需要再添加一个磁盘的大小.或者说Centos7系统需要扩展磁盘空间. 步骤 1.VirtualBox新建磁 ...

  4. Android 基础 (四大组件,五大存储,六大布局)

    Android四大组件: 参考:https://blog.csdn.net/shenggaofei/article/details/52450668 Android四大组件分别为activity.se ...

  5. http://ctf.bugku.com/challenges#Easy_Re

      今天做一道逆向题,开心,见证了自己汇编的用途.     首先看它是否加壳? 1.加壳检测   是vc编程的,没有加壳,可以愉快地分析了.   2.分析程序,找到flag.   首先运行一下子程序, ...

  6. http://www.bugku.com:Bugku——Easy_vb

      之前复习了汇编等知识,这是人生中第一个逆向题目,嘻嘻.   启程.   对于执行文件,首先需要看它是32位还是64位的.这里了解到静态工具IDA的启动程序为idaq.exe和idaq64.exe( ...

  7. 并发编程中Future和Callable使用

    Future模式非常适合在处理很耗时很长的业务逻辑时进行使用,可以有效的减少系统的响应时间,提高系统的吞吐量. 看一个小的demo: 看一下执行结果: 这是异步去获取结果的示例,在子线程去处理任务的时 ...

  8. 一字一句的搞懂vue-cli之vue webpack template配置

    webpack--神一样的存在.无论写了多少次,再次相见,仍是初见.有的时候开发vue项目,对尤大的vue-cli感激涕零.但是,但是,但是...不是自己的东西,真的很不想折腾.所以,我们就得深入内部 ...

  9. 用脚手架创建vue项目

    .创建文件地址 首先创建一个文件夹,我用的HBuilder编辑器 , 然后把文件夹拖入编辑器 , 在你创建的文件夹里面打开cmd 2.输入安装命令 : 1). npm install --global ...

  10. cpio解压initramfs.img

    一.解压initramfs.img # mkdir test # cp /boot/initramfs.img /test # cd test # file initramfs.img initram ...