zoukankan      html  css  js  c++  java
  • DOM

    DOM

    node类型(基本类型,以下其他类型的鼻祖)

      1、nodeType

          parentNode:父节点

          childNodes:子节点(理解成一个数组)

           someNode.firstChild == someNode.childNodes[0];

           someNode.lastChild == someNode.childNodes[someNode.childNodes.length-1];

           previouSiblings和nextSibling:兄弟节点

           hasChildNodes()判断是否有子节点

           元素文本都算是节点

      2、操作节点

          插入

            appendChild();向末尾插入,(标签的里面)

            insertBefore();将节点插入到某个特定位置,第一个参数插入的节点,第二个参数参照节点

          替换

            replaceChild():第一个参数:新节点,第二个参数是要替换的

          移除

            removeChild(node);节点参数

            

          复制

            cloneNode();布尔参数,true是深复制

    Document类型(对象)(获得,写入文档节点,location用法)

      document对象是window对象的属性。

      1、文档信息

          documentElement属性(指向html元素)

          body属性(body元素)

          document.doctype;//取得<!DOCTYPE>的引用

            document.title:获取或设置title的值

          取:var title = document.title

          改:document.title = “xxx”

      2、网页信息

          

            document.location.href === document.URL

          (在console打印时少用等号)

            例:document.domain = "www.baidu.html",domain是可以设置的

          获取前一个页面的url:document.referrer       

          location对象的用法,以下新增

          

        3、获取元素

          getElementById();取得id

          getElementsByTagName();取得标签名

          getElementByName();根据name属性名返回元素,常用在单选按钮中

      4、写入元素

          write():字符串参数,直接原样输出到文档流中,在页面加载完成后执行会复写整个页面

          writeIn();同上,但是在末尾会添加换行符  

          open(),close()打开或关闭网页的输出流

    Element类型(创建标签名和属性特性的操作)

      提供了对元素标签的名,子节点及特性的访问

      1、访问标签名

          元素.tagName;//"DIV"

          元素.nodeName;//"DIV"

      2、html

          属性:id,className,title,lang,dir,这些属性都可以用来获取或修改属性值

            var ele = document.getElementById("id");

          获取:

            alert(ele.id);

          修改:

            ele.id = "someOtherId";

      3、取得元素特性

          getAttribute(属性名);//ele.getAeeribute("id");//id//getAttribute("class")

            特点:style特性,用getAttribute();访问获取到的是css文本,通过属性访问则会返回一个对象。

      4、设置元素特性

          setAttribute("设置的特姓名",值);

            ele.setAttribute("class","newClass");

            另一种写法:ele.class = "newClass";//注意自定义的属性这样修改会报错

      5、删除元素的特性

          removeAttribute();会彻底删除元素特性

      6、attributes属性

          只有Element类型使用,动态的特性类型集合,包含NameNodeMap对象,有以下方法(不常用)

             (nodeName:特性名称,nodeValue:特性的值)

            getNamedItem(name);返回nodeName属性等于name的节点;

            removeNamedItem(name);移除nodeName属性等于name的节点;返回的是被删除的节点

            setNamedltem(node);向列表中添加节点

            item(pos);返回位于数字pos处的节点

            例:var id  = ele.attributes.getNamedItem("id").nodeValue;//获取元素的id特性

              var id = ele.attributes["id"].nodeValute;//这里把attributes理解为对象

              设置新值:

              ele.attributes[”id“].nodeValue = "newid";

          用这个属性来迭代属性的值,attributes.length,用for遍历(把元素属性封装到数组里

      7、创建新元素

          document.createElement(标签名);

          例:var div = document.createElement("div");

            div.id = "newId"

          只是创建了个新元素,但未把它添加到文档树里

      8、将新元素添加到文档树里

          document.body.appendchild(div);

    text类型

      纯文本内容,不能包含元素标签,没有子节点

      访问

          nodeValue属性和data属性

       创建

          document.createTextNode();

      

      添加

          appendData(text);将内容添加到节点末尾(标签里面)

        插入

          insertData(offset,text);在offset位置插入count

      删除

          deleteData(offset,count);从offert位置开始删除count个字符

      替换

          replaceData(offset,count,text);用text替换offset到count的文本

      分割

          splitText(offset);从offset开始将文本分为两个文本节点

          返回从数字开始之后的文本,包含数字下的那个字符。原文本留下数字之前的文本。

      获取

          substringData(offset,count);提取从offset开始到count结尾的文本

      length属性

          nodeValue.length = data.length

      合并文本节点,假设一个元素下有两个文本节点,用这个方法合并后只有一个

          normalize();

    Comment类型

      注释相关,和text类型继承同一个基类

      创建注释

          document.createComment();

    CDATASection类型

      用在XML文档下,表示CDATA区域

    DocumentType类型

      包含文档有关doctype的有关信息

    DocumentFragment类型

      创建了文本片段,不会显示在文档流中,当作一个备用仓库使用

      创建

          document.createDocumentFragment(); 

    Attr类型

      表示元素特性,特性也就是存在于attributes属性中的节点

        属性:name,value,specified:布尔值,区别指定的还是默认的

      创建

          document.createAttribute();

      赋值

          var attr = document.createAttribute("align");

          attr.value = "left";

      获取

          ele.attributes["align"].value

          ele.getAttributeNode("align").value;

          ele.getAttribute("value");

      添加

          ele.setAttributeNode("align");

    DOM操作技术

    动态脚本

        创建随时调用的脚本

        

           用script元素的text属性来添加脚本内容

          或者用appendChild()来添加(ie下会出错),执行起来有点像eval()方法

    动态样式

      创建外部样式

      

      创建内部样式(会实时执行)

      

      以上添加样式代码在ie下会出错,另一个方法:

        style.styleSheet.cssText = "body{100px;}",

        styleSheet是style元素的属性

    操作表格

      各种table属性。。。

    使用NodeList

      有点像NamedNodeMap和HTMLCollection

      动态的dom流,可以用for,length属性迭代,每次访问都会查询一次文档,所以要减少直接对dom的操作。

    总结:

          1、node是最基本的节点类型,其他类型都继承自它。

          2、document类型表示整个文档,跟节点,document是document类型的实例。

          3、element节点表示文档的html和xml元素。

          4、操作文本节点。

    DOM拓展

    选择符API

      document类型新增

      1、querySelector();接收一个css选择符

          

      2、querySelectorAll();接收一个css选择符

          取得该选择符下的所有元素,返回一个NodeList

          例:var p = document.querySelectorAll("p strong");//取得p元素下的所有strong元素

      element类型新增

      3、matchesSelector();接收一个css选择符参数,判断元素是否是个css选择符的引用,返回true或者false。不常用

    元素遍历(查找)

      节点类型

          childElementCount:返回子元素的个数,不包括文本节点和注释

          filstElementChild:返回第一个子元素,firstChild的元素版

          lastElementChild:返回最后一个子元素

          previousElementChild:返回前一个同胞元素,previousSibling的元素版

          nextElementChild:返回后一个同胞元素,nextSibling的元素版

    HTML5

      类相关

          1、getElementsByClassName();

              例:取得id为text下的所有类名为info的元素

              document.getElementById("text").getElementsByClassName("info");

          2、元素的classList属性,表示元素的类列表,同样这个属性是新集合DOMTokenList的实例,它有以下方法(兼容性较差)

              添加类

                add(value);

                例:ele.classList.add("newClass")

              判断是否存在类

                contains(value);返回布尔值

              删除

                remove(value);

              删除或给定,有则删除,无则添加

                toggle(value);

      焦点管理

          1、document.activeElement:获得当前获得焦点的元素,文档加载完表示的是body,加载中是null

          2、document.hasFocus():检查文档是否获得焦点,用这个方法判断用户是否正在与页面交互 

      HTMLDocument的变化

          1、readyState属性

              两个值:

                loading正在加载的文档

                complete已经加载完成的文档

              if(document.readyState == complete){}等于onload事件

          2、compatMode属性,区分页面渲染模式

              两个值:

                CSS1Compat:标准模式

                BackCompat:混杂模式

           3、document.head属性,兼容性差

      字符集属性(编码相关)

          1、document.charset = "UTF-8";修改charset的值

          2、defaultCharset:表示浏览器默认的字符集是什么,兼容性差

      自定义数据属性

          为元素添加属性,但要data-为开头,

              例:<div id="add" data-num = "123"></div>

          dataset属性来获取或设置自定义属性

              例:ele.dataset.num = "1234";//这个ele最好是id获取的元素,唯一的

      插入标记

          1、innerHTML属性:返回或调用元素的所有子节点(包括注释和文本)类似于jq的html()方法。

            

              不能单纯的直接插入script和style标签

          2、outerHTML属性

              可读:获取调用元素的所有子节点的html标签

              修改:替换包括调用元素在内的所有内容

          3、insertAdjacentHTML()方法

              

          4、scrollIntoView()方法:对所有html元素可用,滚动页面,让元素出现在视口中,兼容差

    专有拓展

      1、文档模式

      2、children属性

          表示元素子节点,等同于childNodes

      3、contains()方法

          检查某个元素是不是被调用元素(使用这个方法的祖先元素)的子元素。是,则返回对,接收一个元素参数。

      4、插入文本

           innerText属性:会返回调用元素下的所有节点数里的文本内容(会拼接起来),修改的话也会全部复写可以添加html代码。如果要过滤掉html代码,在使用一遍innerText即可。在ie的兼容上可以使用textContent 

          outerText属性:调用和innerText一样,但是修改会完全覆盖元素,包括调用的元素,也就等同于删除了调用元素,不建议使用。 

      5、滚动

          scrollIntoViewIfNeeded(alignCenter);

          scrollByLines(lineCount);

          scrollByPages(pageCount);

      

    DOM2和DOM3

      这部分内容就是升级了dom的用法,增加了许多属性方法,加强了交互功能。

      DOM变化

          1、DocumentType类型,新增3个属性:

              publicId,systemId,internalSubset,这三个都是有关文档类型声明的属性

          2、视图模块新增defaultView属性,指向给定的窗口,是视图部分唯一新增的属性,ie不支持,但在ie下有个等价的属性parentWindow

             3、创建新html文档document.implementation.createHTMLDocument("new doc");兼容很差

          4、一些node类型的变化

              比较节点的引用对象和类型返回布尔值:isSameNode()和isEqualNode(),参数是比较节点,可以使被调用的节点也可以是其他节点

              setUserData(),将属性,值,函数绑定给某个节点,三个参数,属性,value,数据处理函数

                  例:document.body.serUserData("name","newBody",function(){})

              getUserData(),获得设置的属性值

                  例:var data = document.body.getUserData("name")

          5、框架的变化

      样式 

         (style属性)针对行内

            访问:

              ele.style.backgroundImage//ele.style.color//ele.style.cssFloat!!

            获取:alert(ele.style.color)

            重写:cssText

              ele.style.cssText = "color:red;font-size:10px";

            遍历:length,item()

            getPropertyValue(属性名)方法;返回属性值的字符串表示

              ele.style.getPropertyValue("color")

            删除

              ele.style.removeProperty("border");

          计算的样式(不管是行内还是外链等等)都是只读的用法

              1、document.dafultView.getComputedStyle("要计算样式的元素",“伪元素的字符串,例:after,没有就填null”)

              

                ie不支持,但是有个相同的属性:ele.currentStyle

           操作样式表(链入样式表和<style>插入的样式表)

                1、文档中样式表的集合:document.styleSheets,有个length属性

                  getStyleSheet():返回某个样式表对象

                2、css规则

            元素大小(元素的属性,只读的)

                offsetHeight,offsetWidth:元素的宽高,包括边框,水平滚动条

                offsetLeft,offsetTop:元素的外边框到包含元素的内边框间的距离

              

                如果容器是body,那么getElementLeft()和offsetLeft是一样的

           客户区大小(只读的)

                clientWidth属性:内容区宽度加内边距宽度

                clientHeight属性:同上

              

              浏览器的视口大小:document.body.clientWidth。。。

          滚动

              scrollHeight:没有滚动条的情况下,元素内容的总高度,可以获取元素的实际高度

              scrollWidth:同上

              scrollLeft:被隐藏在内容区域左侧的像素数,设置这个属性可以改变元素的滚动位置

              scrollTop:同上,scrollTop = 0;让元素滚回到顶部

            

           确定元素的大小

            getBoundingClientRect(),返回元素的一个矩形模型,有left,right,top,bottom四个属性,表示相对于视口的位置

      遍历

        dom2定义了两个用于顺序遍历dom结构的类型:NodeIterator和TreeWalker,IE不支持遍历dom

            1、NodeIterator

              创建该类型的实例:document.createNodeIterator() 四个参数

              主要方法:nextNode()向前遍历,previousNode()向后遍历

            2、TreeWalker

              升级版遍历,多方向遍历,除了上述两个方法,还有:

                parentNode();父节点,

                firstChild();第一个子节点

                lastChild();当前节点最后一个子节点;

                nextSibling();当前节点的下一个同辈节点;

                previousSibling();遍历到当前节点的上一个同辈节点

              创建一个遍历实例:document.createTreeWalker();同样有四个参数

      范围

        选择文档中的一个区域

         创建dom范围:var range = document.createRange();

           每个范围是range类型的实例,有以下属性或方法    

              添加内容:

                selectNode(),接收一个dom节点,用该节点内容来填充范围,会选择整个节点,包括子节点。

                selectNodeContents(),只选择节点的子节点

              实现复杂选择:

                setStart()和setEnd()

          操作dom范围里的内容

            删除:1、deleteContents()

               2、extractContents();也是删除,但是它会返回范围的文档片段,可以用这个返回的添加到其他元素里

            克隆:cloneContents,复制文档片段的一个副本

            插入:insertNode();向范围选取的开始出插入一个节点

               surroundContents:环绕范围添加内容

            折叠:collapse();一个参数,true折叠到开始位置,false折叠到结束位置

            比较:compareBoundaryPoints();来确定某些范围是否有公共边界

            复制:cloneRange();复制范围的一个副本

            清理使用后的范围:detach();一旦清除就不能在使用了      

              

              

          

        

          

           

                    

          

              

          

              

          

      

      

        

        

      

        

     

         

            

          

              

          

          

          

      

  • 相关阅读:
    从零开始学习内网渗透之域环境的搭建
    ssrf漏洞学习(PHP)
    自己写的Weblogic的poc
    某CTF平台一道PHP代码审计
    某CTF平台一道PHP代码注入
    从xxe-lab来深入学习xxe漏洞
    Git常用命令
    一个简单的基于MINI2440开发板的启动代码
    面试题
    Linux多线程及线程同步简单实例
  • 原文地址:https://www.cnblogs.com/Grace-zyy/p/8362416.html
Copyright © 2011-2022 走看看