JavaScript DOM

DOM—— Document Object Model 文档对象模型

  • Documenta对象 —— XML文档(HTML标签)

  • Element对象 —— 除了html以外的其他标签

  • Element-Text —— 文本内容

  • Object —— 把文档变成对象


    DOM

DOM API

1、Node

1.1、Node组成:

Node 是 Document(html) 对象、Element对象 和Text文本对象 以及其它不重要的对象的原型链的顶端。

    页面中的节点Node 通过各种对象的构造函数构造出对象,这就是DOM API,这就是DOM的主要功能。

2、三种DOM API

2.1、Node的接口:

1、属性:

childNodes,firstChild,children,innerText,lastChild,nextSibling,nodeName,nodeType,nodeValue,outerText,ownerDocument,parentElement,parentNode,previousSibling,textContent ;
注意:【考】
1、 nextSibling //可能会获取到文本,不只是标签
2、innerText和textContent有细微差别
3、nodeType 不同的值

节点常量类型:

常量 描述
Node.ELEMENT_NODE 1 一个元素节点,例如<p>和<div>
Node.TEXT_NODE 3 Element或Atrr中实际文字
Node.CDATA_SECTION_NODE 4 一个 CDATASection
Node.PROCESSING_INSTRUCTION_NODE 7 一个用于XML文档的 ProcessingInstruction
Node.COMMENT_NODE 8 一个 Comment节点
Node.DOCUMENT_NODE 9 一个 Document节点
Node.DOCUMENT_TYPE_NODE 10 描述文档类型的DocumentType节点
Node.DOCUMENT_FRAGMENT_NODE 11 一个DocumentFragment节点

【记住 DocumentFragment 优化】
*DocumentFragment,文档片段接口,表示一个没有父级文件的最小文档对象。它被作为一个轻量版的 Document 使用,用于存储已排好版的或尚未打理好格式的XML片段。最大的区别是因为 DocumentFragment 不是真实DOM树的一部分,它的变化不会触发 DOM 树的重新渲染,且不会导致性能等问题。

最常用的方法是使用文档片段作为参数(例如,任何 Node 接口类似 Node.appendChildNode.insertBefore) 的方法),这种情况下被添加(append)或被插入(inserted)的是片段的所有子节点, 而非片段本身。因为所有的节点会被一次插入到文档中,而这个操作仅发生一个重渲染的操作,而不是每个节点分别被插入到文档中,因为后者会发生多次重渲染的操作。

该接口在Web组件中也非常有用: 模板 元素在其 HTMLTemplateElement.content 属性中包含了一个 DocumentFragment 。

可以使用document.createDocumentFragment(https://developer.mozilla.org/zh-CN/docs/Web/API/Document/createDocumentFragment "创建一个新的空白的文档片段( DocumentFragment)。") 方法或者构造函数来创建一个空的 DocumentFragment.

2、方法:(如果一个属性是函数,就称为方法,换言之,方法就是函数属性)
  • appendChild() //向节点的子节点列表末尾添加新的节点
  • cloneNode(true/false) //如果true,深拷贝,则节点本身及节点中所有的后代元素都会被递归地克隆,如果false只拷贝节点本身
  • contains()
  • hasChildNodes()
  • insertBefore()
  • isEqualNode() // 相等就返回true,不一定是同一个
  • isSameNode() //相当于 === 号,同一个
  • removeChild() //把子元素从页面中删掉之后它依然在内存中
  • replaceChild()
  • mormalize() //常规化

【总结】:以上这些API功能:增删改查节点

2.2、Document的接口:

1、属性:
  • anchors
  • body
  • characterSet //字符集编码
  • childElementCount
  • children
  • doctype
  • documentElement //html
  • domain
  • fullscreen
  • head
  • hidden
  • images
  • links
  • location
  • onxxxxxxxxx //一系列事件监听
  • origin
  • plugins //插件
  • readyState //下载状态
  • referrer //引荐者
  • scripts
  • scrollingElements
  • styleSheets
  • title
  • visibilityState
2、方法:
  • close
  • createDocumentFragment()
  • createElement()
  • createTextNode()
  • execCommand() //执行命令
  • exitFullscreen()
  • getElementByBody()
  • getElementsByClassName()
  • getElementsByName()
  • getElementsByTagName()
  • getSelection()
  • hasFocus()
  • open()
  • querySelector()
  • querySelectorAll()
  • registerElement
  • write()
  • writeIn() //写一行
    注意:【考】
    1、querySelector() //返回一个元素
    2、querySlectorAll() //返回多个元素组成的数组,即使只有一个元素还是会返回伪数组,还可以选择其中某一个例如:querySlectorAll[5]

2.3、Element的接口:

属性:
  • Atrributes //获取一个元素的所有属性
  • classList
  • className
  • cliemtWidth/Height/Top/
  • id
  • innerHtml //会把用户写的标签执行;但是innerText不会执行,只当作文本传到页面
  • tagName
  • scorllHeight
  • getAttribute
  • querySelector
  • querySelectorAll
  • removeAttribute
  • remove
  • setAttribute

DOM 细微区别总结:

  • DOM 有自己的国际标准,目前的通用版本是
  • DOM的最小组成单位叫做 节点Node
  • 节点常量类型有7种
  • DOM 树的根节点是html
  • <div id=x></div>中 x的值为这个 id 为 x 的 div 对应的 Element 对象
  • <div id=parent></div> 中parent的值为如果有父窗口,就是父窗口。如果没有,就是当前窗口。
    【重点:全局变量可耻】
* 以上这两个不同原因:前者是最直观的,没有歧义,而后者parent是window全局属性,所以会返回父级对象。这就是全局变量可耻,不能用,用了之后要么被全局变量覆盖,要么覆盖全局变量,避开这个方法:
              1. 不用全局属性,使用局部属性,即写在函数作用域内:
                function x(){
                      var parent = document.querySelector('#self')
                }
            * 方法 1 扩展 知识点:
              不用全局属性,使用局部属性,立即调用函数:
              就是:声明一个匿名函数,并立即调用这个函数
              function (){
                  var parent = document.querySelector('#self')
                }.call()   
             * 立即调用函数的浏览器端bug:声明一个匿名函数,并立即调用这个函数后浏览器会报错,破解这个bug的方法:
              (1). 把整个立即调用函数用圆括号括起来
              (2). 把整个匿名函数用圆括号括起来。再立即调用
              (3). 在整个立即调用函数前面写一个 【减号】 或 【加号】或 【感叹号】或 【波浪号】  (不需要用到真是值的情况下,只要让浏览器知道不是一个声明,而是一个立即调用函数就可以,其中 !是取反;~ 是二进制取反)
              (4). 不用关键字var ,而是用let关键字,然后把整个代码块放到花括号里面,原因:var会变量提升到花括号外面,而let不会,所以这样做只能把变量使用在花括号里,因此,用let 有利有弊
              2. 非要使用全局属性,就写成下面这样:
                   html骨架:
                  <div id = 'self'></div>
                   js:
                  var selfDiv = document.querySelector('#self')
                接着就可以正常使用这个变量名了
  • <div id=parent1><div id=child1></div></div> 中parent1.childNodes 的值是 {0:child1, length:1} 伪数组

  • 【代码执行顺序有关题目:】
    第一题:
    var parent = document.getElementById('parent');
    parent.childNodes.length 为 2
    parent.appendChild(document.createElement('div'));
    parent.childNodes.length // 请问现在 length 是多少
    //3
    //原因:修改之后再次运行了parent就是再次取值了,所以会变

    第二题:
    var allDiv = document.querySelectorAll('div')
    allDiv.length // 假设是 2
    document.body.appendChild( document.createElement('div') )
    allDiv.length // 请问现在 length 的值是多少???
    //2
    //原因:值是之前保存在内存中的length,修改之后没有再次取值

* HTMLCollection与NodeList的区别有
   * HTMLCollection实例对象的成员只能是Element节点,NodeList实例对象的成员可以包含其他节点
   * HTMLCollection实例对象可以用id属性或name属性引用节点元素,NodeList只能使用数字索引引用。
* ChildNode接口用于处理子节点(包含但不限于Element子节点)。Element节点、DocumentType节点和CharacterData接口,部署了ChildNode接口。凡是这三类节点(接口),都可以使用哪些方法:
回答:remove()/before()/after()/replaceWith()


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,036评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,046评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,411评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,622评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,661评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,521评论 1 304
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,288评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,200评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,644评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,837评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,953评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,673评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,281评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,889评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,011评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,119评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,901评论 2 355