今天简单整理了一下js三部曲之DOM部分的内容,二话不说先上笔记:

1.什么是DOM?
  Document Object Model,即文档对象模型,它是让JavaScript能够操作html和xml的一系列编程接口

2.<html></html>标签代表的是文档的根标签而不是整个文档,document代表的才是整个文档

3.查看元素节点
  document.getElementById() // 元素id在ie8以下的浏览器不区分大小写,而且也返回匹配name属性的元素。不过不常用,因为在开发的时候一般自己写的页面中只能出现一次或少数几次id,而这个id通常出现在页面顶层以作为后端抽取代码的接口
  document.getElementsByTagName() // 生成的是一个类数组对象,包括之后所有DOM和BOM系统给我们生成的成组的东西都是类数组对象。还有这个获取元素的方法是最主流的用法,它没有什么兼容性的问题。需要注意的是可以写成document.getElementsByTagName('*')
  document.getElementsByClassName() // ie8及以下的版本中没有这个方法
  document.getElementsByName() // 只有部分标签才需要添加name属性用意提交数据(表单、表单元素、img、iframe),在之前的浏览器里面给div等元素添加name属性是不能被识别的,所以不常用
  querySelector() // css选择器(在css中怎么选择,到了这里就可以怎么选择,比如.one>.two .three),在ie7及以下的版本中没有。因为选出来的元素不是实时的,所以在用法上及其受局限
  querySelectorAll() // 同上

4.遍历节点树
  parentNode // 父节点(最顶端的parentNode为#document,再向上返回null)
  childNodes // 子节点们
  firstChild
  lastChild
  nextSibling // 后一个兄弟节点
  previousSibling // 前一个兄弟节点

5.节点的类型(nodeType)
  元素节点 // 1
  属性节点 // 2
  文本节点 // 3
  注释节点 // 8
  document // 9
  documentFragment // 11。这是一个DOM元素占位符,用于将其子元素插入HTML文档树

6.节点的四个属性
  nodeName // 元素的标签名,以大写形式表示,只读
  nodeValue // 只有文本节点和注释节点有,text节点或comment节点的文本内容,可读写
  nodeType // 该节点的类型,只读
  attributes // 节点的属性集合

7.节点的一个方法:.hasChildNodes() // 是否含有子节点

8.基于元素节点树的遍历
  parentElement // 返回当前元素的父元素节点(ie9及以下不兼容)
  children // 返回当前元素的元素子节点(ie4.5有兼容问题)
  firstElementChild // 返回第一个子元素节点(ie9及以下不兼容)
  lastElementChild // 返回最后一个子元素节点(ie9及以下不兼容)
  nextElementSibling // 返回后一个兄弟元素节点(ie9及以下不兼容)
  previousElementSibling // 返回前一个兄弟元素节点(ie9及以下不兼容)

9.DOM结构树
  Node{
    Document{
      HTMLDocument
      XMLDocument
    }
    CharacterData{
      Text
      Comment
    }
    Element{
      HTMLElement{
        HTMLHeadElement
        HTMLBodyElement
        HTMLTitleElement
        HTMLParagraphElement
        HTMLInputElement
        HTMLTableElement
        etc.
      }
      XMLElement
    }
    Attr
  }

10.DOM结构树注意点
  ①getElementById方法定义在Document.prototype上,即Element节点上不能使用
  ②getElementsByName方法定义在HTMLDocument.prototype上,即非html中的document以外不能使用(XMLDocument,XHLElement)
  ③getElementsByTagName方法定义在Document.prototype和Element.prototype上,即既可以通过document.getElementsByTagName查找也可以通过div.getElementsByTagName查找
  ④HTMLDocument.prototype定义了一些常用的属性,document.body、document.head分别指代HTML文档中的<body><head>标签
  ⑤Document.prototype上定义了documentElement属性,指代文档的根元素,在HTML文档中,它总是指代<html>元素
  ⑥getElementsByClassName和querySelector、querySelectorAll在Document.prototype和Element.prototype上均有定义

11.增加节点的方法
  document.createElement()
  document.createTextNode()
  document.createComment()
  document.createDocumentFragment()

12.插入节点的方法
  PARENTNODE.appendChild() // 把页面中的一个元素节点添加到另一个地方相当于剪切操作
  PARENTNODE.insertBefore(a, b) // 在PARENTNODE里面insert a before b

13.删除节点的方法
  PARENTNODE.removeChild() // 返回被remove的节点
  SELFNODE.remove() // 返回被remove的节点

14.替换节点的方法
  PARENTNODE.replaceChild(new, origin)

15.Element节点的一些属性
  innerHTML
  innerText(老版本火狐不兼容)
  textContent(老版ie不好使)

16.Element节点的一些方法
  ELEMENT.setAttribute('name', 'value')
  ELEMENT.getAttribute('name')
  如果是想要修改或添加某个元素节点的class或id属性,那么可以简单的写作ELEMENT.className或是ELEMENT.id

  以上是我的笔记。这些基本上是DOM中用的比较多的,同时给出了浏览器的兼容性问题,希望对读者在DOM这一块有所帮助。

  如有错误或是不足,还请指出,我将尽快查证补漏!

DOM知识点总结的更多相关文章

  1. Javascript + Dom知识点总结

    Javascript + Dom知识点总结 1.用Javascript声明数组和字典的方式 // 数组声明 var arr = new Array(); arr["0"] = &q ...

  2. javasctipt之DOM知识点

    一:DOM节点 子节点:childNodes 父节点:parentNode offsetPrent 二:元素属性操作 方式一:xxx.style.xxx 方式二:xxx.style["xxx ...

  3. HTML DOM 知识点整理(一)—— Document对象

    一.DOM对象 DOM对象整体包括: HTML DOM Document对象 HTML DOM 元素对象 HTML DOM 属性对象 HTML DOM 事件对象 HTML DOM Console 对象 ...

  4. HTML DOM知识点补充:

    DOM Console 控制台对象提供了浏览器的debug的方法支持. 常用的:console.log(). ⚠️coffeescript中,这个方法不加括号. DOM Document 当一个HTM ...

  5. DOM 知识点梳理(笔记)

    1998年10月DOM1级规范成为了W3C的推荐标准,为基本的文档结构及查询提供了接口. 一.Node类型 每个节点都有个nodeType属性,表明了节点的类型.共有12种类型: 元素节点       ...

  6. 前端DOM知识点

    DOM即文档对象模型(Document Object Model,DOM)是一种用于HTML和XML文档的编程接口.它给文档提供了一种结构化的表示方法,可以改变文档的内容和呈现方式.DOM把网页和脚本 ...

  7. XML DOM 知识点

    第一部分[DOM基础] DOM介绍: 1.什么是 HTML DOM? HTML DOM 定义了所有 HTML 元素的对象和属性,以及访问它们的方法(接口). 2.什么是 XML DOM? XML DO ...

  8. 《对象及DOM知识点及其应用1》

    1.图片间的来回切换用if{}else{}; <超链接方式的切换图片(常用)>如:<a href="../images1/1-small.jpg" id=&quo ...

  9. JS DOM与BOM

    DOM知识点 [DOM(文档对象模型)是 HTML 和 XML 的应用程序接口(API).DOM代表着被加载到浏览器窗口里的当前网页:浏览器向我们提供了当前网页的地图(或者说模型),而我们可以通过js ...

随机推荐

  1. c语言——鞍点

    描述 找出具有m行n列二维数组Array的“鞍点”,即该位置上的元素在该行上最大,在该列上最小,其中1<=m,n<=10. 输入 输入数据有多行,第一行有两个数m和n,下面有m行,每行有n ...

  2. 关于SpringMVC的配置流程以及一些细节

    首先说道SpringMvc是什么,SpringMVC是Spring框架里面的一个子框架,它对网站前后端的代码分层做了一套实现,这套实现给我们带来了几个好处,首先第一,SpringMVC实现了一个请求对 ...

  3. Python帮助

    我们可以很容易的通过Python解释器获取帮助.如果想知道一个对象(object)更多的信息,那么可以调用help(object)!另外还有一些有用的方法,dir(object)会显示该对象的大部分相 ...

  4. python库-Arrow处理时间

    Arrow是一个处理时间的python库,能一键转换dates/times/timestamps等时间格式而不需要大量导致各种时间模块和格式转换函数,十分快捷方便 使用Arrow需要两步转换操作: 1 ...

  5. SQLalchemy 字段类型

    常用的SQLAlchemy列选项 类型名 python中类型 说明 Integer int 普通整数,一般是32位 SmallInteger int 取值范围小的整数,一般是16位 BigIntege ...

  6. python学习笔记-os模块参数

    python的os 模块提供了非常丰富的方法用来处理文件和目录.常用的方法如下表所示: os.access(path, mode) 检验权限模式 os.chdir(path) 改变当前工作目录 os. ...

  7. Podfile

    platform :ios, "9.0" target "APPName" dopod 'AFNetworking'pod 'SVProgressHUD'pod ...

  8. MySQL基本操作——1

    1.命令行启动或关闭MySQL服务:方式一:计算机--右击管理--服务方式二:net start MySQL服务器名称net stop MySQL服务器名称 2.登录和退出(必须在MySQL服务启动的 ...

  9. HTML5网页制作(3)

    今天,就开始嵌入图片以及创建图片分区的学习吧! 这两张图片其实是我用HTML5写的(纯粹当做笔记来记了),以上就是今天要学的一些内容 下面是我今天敲的代码:  [冒泡]林北的爸爸 2019/4/29  ...

  10. PAT乙级考前总结(一)

    数学相关的题目 1001 害死人不偿命的(3n+1)猜想 (15 分) 直接一步步计数 1005 继续(3n+1)猜想 (25 分) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目 ...