美文网首页
JavaScript DOM

JavaScript DOM

作者: Qingelin | 来源:发表于2019-08-18 23:16 被阅读0次

    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()
    
    
    

    相关文章

      网友评论

          本文标题:JavaScript DOM

          本文链接:https://www.haomeiwen.com/subject/scprjctx.html