第十二章 DOM2和DOM3

一.DOM变化

1.针对XML命名空间的变化

2.其他方面的变化

二.样式

1.访问元素的样式

            .style
            1)DOM样式属性方法
                cssText:访问style特性中的CSS代码
                length:应用给元素的CSS属性数量
                parentRule:表示CSSRule对象
                getPropertyCSSValue(propertyName):返回包含给定属性值的CSSValue对象
                getPropertyPriority(propertyName):如果给定的属性使用了!important设置,则返回"important";否则,返回空字符串
                getPropertyVlue(propertyName):返回给定属性的字符串值
                item(index):返回给定位置的CSS属性的名称
                removeProperty(propertyName):从样式中删除给定属性
                setProperty(propertyName,value,priority):将给定属性设置哦为相应的值,并加上有限标志(“important”或者一个空字符串)
                -cssText:
                    myDiv.style.cssText="width:25px;height:100px;background-color:green";
                    alert(myDiv.style.cssText);
                    //为元素应用多项变化的快捷方式
                -length:
                    for( var i=0,len=myDiv.style.length;i<len;i++)
                        {
                              alert(myDiv.style[i]);//或者myDiv.style.item(i)  
                         }
                2)计算的样式
                    

2.操作样式表

          CSSStyleSheet类型表示的是样式表
            1)css规则
                CSSStyleRule对象:
                div.box{
                 background-color:blue;
                width:100px;
                height:200px;
               }
                var sheet =docuemnt.styleSheets[0];
                var rules=sheet.cssRules || sheet.rules;//取得规则列表
                var rules = rules[0];//取得第一条规则
                alert(rule.selectorText);//"div.box"
                alert(rule.style.cssText);//完整的CSS代码
                alert(rule.style.backgroundColor);//"blue"
                alert(rule.style.width);//"100px"
               alert(rule.style.height);//"200px"
            2)创建规则
                要向现有样式表中添加新规则,需要使用inserRule()方法:两个参数:规则文本和在哪里插入规则的索引
                sheet.insertRule("body{background-color:silver}",0);//DOM方法
           3)删除规则
                deleteRule(); 一个参数:要删除的位置
                sheet.deleteRule(0);//DOM方法
                sheet.removeRule(0);//仅对IE有效

3.元素大小

            1)偏移量:
                offsetHeight、 offsetTop、 offsetWidth、 offsetlLeft。
            2)客户区大小:元素内容及其内边距所占空间的大小
                clientWidth、 clientHeight。
            3)滚动大小
              
        4).确定元素大小
            
  1. function getElementLeft(element){
  2. var actualLeft = element.offsetLeft;
  3. var current = element.offsetParent;
  4. while (current !== null){
  5. actualLeft += current.offsetLeft;
  6. current = current.offsetParent;
  7. }
  8. return actualLeft;
  9. }
  10. function getElementTop(element){
  11. var actualTop = element.offsetTop;
  12. var current = element.offsetParent;
  13. while (current !== null){
  14. actualTop += current. offsetTop;
  15. current = current.offsetParent;
  16. }
  17. return actualTop;
  18. }
  19. function getBoundingClientRect(element){
  20. var scrollTop = document.documentElement.scrollTop;
  21. var scrollLeft = document.documentElement.scrollLeft;
  22. if (element.getBoundingClientRect){
  23. if (typeof arguments.callee.offset != "number"){
  24. var temp = document.createElement("div");
  25. temp.style.cssText = "position:absolute;left:0;top:0;";
  26. document.body.appendChild(temp);
  27. arguments.callee.offset = -temp.getBoundingClientRect().top - scrollTop;
  28. document.body.removeChild(temp);
  29. temp = null;
  30. }
  31. var rect = element.getBoundingClientRect();
  32. var offset = arguments.callee.offset;
  33. return {
  34. left: rect.left + offset,
  35. right: rect.right + offset,
  36. top: rect.top + offset,
  37. bottom: rect.bottom + offset
  38. };
  39. } else {
  40. var actualLeft = getElementLeft(element);
  41. var actualTop = getElementTop(element);
  42. return {
  43. left: actualLeft - scrollLeft,
  44. right: actualLeft + element.offsetWidth - scrollLeft,
  45. top: actualTop - scrollTop,
  46. bottom: actualTop + element.offsetHeight - scrollTop
  47. }
  48. }
  49. }
  50. function getDimensions(){
  51. var rect = getBoundingClientRect(document.getElementById("myDiv"));
  52. alert("left: " + rect.left + "\nright: " + rect.right + "\ntop: " + rect.top + "\nbottom: " + rect.bottom);
  53. }
  54. </script>
  55. </head>
  56. <body style="padding: 10px; margin: 0">
  57. <div style="margin: 20px">
  58. <div style="padding: 20px">
  59. <div id="myDiv" style="width: 100px; height: 50px; background-color: red; border: 1px solid black"></div>
  60. </div>
  61. </div>
  62. <input type="button" value="Get Element Dimensions" onclick="getDimensions()" />
  63. </body>
 
 

三.遍历

            ie不支持dom遍历
*深度优先遍历0
检测浏览器对DOM2级遍历能力的支持情况
            var supportsTraversals=docuemnt.implementation.hasFeature("Traversal","2.0");
            var supportsNodeIterator=(typeof document.creatNodeIterator=="function");
            var supportsTreeWalker=(typeof docuemnt.creatTreeWalker=="function");

1.NodeIterator

            document.creatNodeIterator()方法创建实例
            接受参数:
                root:想要作为搜索起点的树中的节点
                whatToShow:想要访问哪些节点的数字代码
                filter:是一个NodeFilter对象,或者一个表示应该接受还是拒绝某种特定节点的函数
                entityReferenceExpansion:布尔值,表示是否要扩展实体引用。用这个参数在HTML页面中没有用,因为其中的实体引用不能扩展。
                eg .
                <div id=" div1">
                 <p><b>hello</b>world!</p>
                <ul>
                   <li>1</li>
                    <li>2</li>
                    <li>3</li> 
               </ul>
               </div>
            想要遍历<div>元素中的所有元素:
            var div=document.getElementById("div1");
            var iterator=docuemnt.creatNodeIterator(div,NodeFilter.SHOW_ELEMENT,null,false);
            var node=iterator.nextNode();
            while(node!=null){
                alert(node.tagname);//输出标签名
                node=iterator.nextNode();    
           }
若只想要返回<li>元素:
        
  1. <head>
  2. <title>NodeIterator Example</title>
  3. <script type="text/javascript">
  4. function makeList() {
  5. var div = document.getElementById("div1");
  6. var filter = function(node){
  7. return (node.tagName.toLowerCase() == "li") ?
  8. NodeFilter.FILTER_ACCEPT :
  9. NodeFilter.FILTER_SKIP;
  10. };
  11. var iterator = document.createNodeIterator(div, NodeFilter.SHOW_ELEMENT, filter, false);
  12. //For Firefox: iterator = document.createTreeWalker(div, NodeFilter.SHOW_ELEMENT, filter, false);
  13. var output = document.getElementById("text1");
  14. var node = iterator.nextNode();
  15. while (node !== null) {
  16. output.value += node.tagName + "\n";
  17. node = iterator.nextNode();
  18. }
  19. }
  20. </script>
  21. </head>
  22. <body>
  23. <p><strong>Note:</strong> The <code>NodeIterator</code> object has only been implemented in Internet Explorer 9, Chrome, Firefox (version 3.5 and higher), Opera (version 7.6 and higher) and Safari (version 1.3 and higher). It has not been implemented in Internet Explorer or Firefox (so this example won't work).</p>
  24. <div id="div1">
  25. <p><b>Hello</b> world!</p>
  26. <ul>
  27. <li>List item 1</li>
  28. <li>List item 2</li>
  29. <li>List item 3</li>
  30. </ul>
  31. </div>
  32. <textarea rows="10" cols="40" id="text1"></textarea><br />
  33. <input type="button" value="Make List" onclick="makeList()" />
  34. </body>
 

2.TreeWalker

                nextNode()和previousNode()
                parentNode()遍历到当前节点的父节点
                firstChild():遍历到当前节点的第一个子节点
                lastChild():遍历到当前节点的最后一个子节点
                nextSibling():遍历到当前节点的下一个同辈节点
                previousSibling():遍历到当前节点的上一个同辈节点
                创建TreeWalker对象
                    document.createTreeWalker()
                        四个参数:遍历起点(根节点)、要显示的节点类型、过滤器、是否扩展实体引用的布尔值。
                        
  1. <script type="text/javascript">
  2. function makeList() {
  3. var div = document.getElementById("div1");
  4. var filter = function(node){
  5. return (node.tagName.toLowerCase() == "li") ?
  6. NodeFilter.FILTER_ACCEPT :
  7. NodeFilter.FILTER_SKIP;
  8. };
  9. var walker = document.createTreeWalker(div, NodeFilter.SHOW_ELEMENT, filter, false);
  10. var output = document.getElementById("text1");
  11. var node = walker.nextNode();
  12. while (node !== null) {
  13. output.value += node.tagName + "\n";
  14. node = walker.nextNode();
  15. }
  16. }
  17. </script>
 
            

四.范围

1.DOM中的范围

                createRange()方法
                     selectNode()选择整个节点,包括子节点
                     selectNodeContents()只选择节点的子节点
                        用DOM范围实现复杂选择
                            setStart() setEnd():参数一个参照节点和一个偏移量
                        deleteContents()
                            <p><b>he</b><b>llo</b>world</p>
                            var p1=document.getElementById("p1");
                                helloNode=p1.firstChlid.firstChild;
                                worldNode=p1.lastChild;
                                range=document.createRange();//创建范围
                                range.setStart(helloNode,2);
                                range.setEnd(worldNode,3);
                                range.deleteContents();
                                结果:
                                    <p><b>he</b>rld!</p>
                                插入DOM范围中的内容:
                                    insertNode();
                                清理DOM范围
                                    range.detach();//从文档中分离
                                    range=null;//解除引用

2.IE8及更早版本中的范围

dom2和dom3的更多相关文章

  1. 12. javacript高级程序设计-DOM2和DOM3

    1. DOM2和DOM3 DOM2级规范定义了一些模块,用于增强DOM1级.“DOM2级核心”为不同的DOM类型引入了一些与XML命名空间有关的方法,这些变化只在使用XML或者XHTML,对于HTML ...

  2. javascript高级程序设计第3版——第12章 DOM2与DOM3

    12章——DOM2与DOM3 为了增强D0M1,DOM级规范定义了一些模块. DOM2核心:为不同的DOM类型引入了一些与XML命名空间有关的方法,还定义了以编程方式创建Document实例的方法: ...

  3. Javascript高级编程学习笔记(49)—— DOM2和DOM3(1)DOM变化

    DOM变化 我们知道DOM有许多的版本,其中DOM0和DOM2这两个级别以对事件的纳入标准而为人所知 但是呢,这里不讲事件,在后面会有专门和事件有关的部分作为详细讲解 这里就只讲一下DOM2和DOM3 ...

  4. DOM2和DOM3读书笔记

    二刷<高程>做的笔记,没什么技术含量就不发到首页啦!~DOM1级主要定义HTML和XML文档底层结构,DOM2和DOM3在这个结构基础上引入更多交互能力,也支持更高级的XML特性.DOM2 ...

  5. [转]DOM0,DOM2,DOM3事件处理方式区别

    转 DOM0,DOM2,DOM3事件处理方式区别 2016年07月13日 15:00:29 judyge 阅读数:1457更多 个人分类: js与前端   引子:        文档对象模型是一种与编 ...

  6. 《JavaScript高级程序设计》笔记:DOM2和DOM3(十二)

    DOM1级主要定义的是HTML和XML文档的底层结构.DOM2级和DOM3级在这个结构基础上引入了更多的交互能力,也支持更高级的XML特性.为此DOM2级和DOM3级分为了很多的模块(模块直接具有某种 ...

  7. 全栈JavaScript之路( 二十四 )DOM2、DOM3, 不涉及XML命名空间的扩展

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/hatmore/article/details/37658167 (一)DocumentType 类型 ...

  8. dom0、dom2、dom3事件

    https://www.jianshu.com/p/3acdf5f71d5b addEventListener():可以为元素添加多个事件处理程序,触发时会按照添加顺序依次调用. removeEven ...

  9. Javascript高级编程学习笔记(54)—— DOM2和DOM3(6)范围选择

    范围 为了让开发人员更加方便地控制页面“DOM2级遍历和范围”模块定义了“范围”接口 通过该接口开发人员可以选择文档中的一个区域,而不必考虑元素的界限 在常规操作不能有效地修改文档时,使用范围往往可以 ...

随机推荐

  1. 关于如何在cenos7.0上实现mysql数据库远程连接

    设置mysql允许别的客户机控制的权限 mysql -uroot -p #此处为本地linux帐号密码 select user,host from mysql.user; #查看mysql表对应use ...

  2. dp 动态规划 hdu 1003 1087

    动态规划就是寻找最优解的过程 最重要的是找到关系式 hdu 1003 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1003 题目大意:求最大字序列和, ...

  3. int unsigned实验

    create table t1(a int unsigned,b int unsigned); insert into t1 select 1,2; select 1-2 from t1; Error ...

  4. 无废话SharePoint入门教程四[创建SharePoint母版页]

    一.前言 文章成体系,如果有不明白的地方请查看前面的文章. 二.目录 1.创建HTML页面 2.将HTML文件转换为SharePoint母版页 3.在 SPD中修改母版页“PlaceHolderMai ...

  5. JavaScript基础之DOM修改样式

    1.获取或设置元素的内容:3个属性:   1. innerHTML: 获取或设置元素开始标签到结束标签之间的所有HTML代码原文.      何时使用:只要获得完整的html代码原文时      优化 ...

  6. flex上下固定中间滚动布局

    传统 pc 端中,子容器高度超出父容器高度,通常使用 overflow:auto 可出现滚动条拖动显示溢出的内容,而移动web开发中,由于浏览器厂商的系统不同.版本不同,导致有部分机型不支持对弹性滚动 ...

  7. 如何在Linux服务器中隐藏PHP版本

    通常,大多数默认设置安装的web服务器存在信息泄露,这其中之一就是PHP.PHP 是如今流行的服务端html嵌入式语言(之一?).在如今这个充满挑战的时代,有许多攻击者会尝试发现你服务端的漏洞.因此, ...

  8. gridview的rowdeleting这个函数总是不执行

    今天在做新闻管理时,管理数据的时候需要弹出确认删除的功能,可是此功能总是不能够实现,调试的时候也执行不到该方法,后来方向是忘记给button加上一个属性: 把CommandName设置为delete. ...

  9. 场景5 Performance Management

    场景5 Performance Management 性能调优(不能重启数据库) 索引 资源管理器 性能优化 统计分析 SQL性能分析 SPM (SQL执行计划管理) 堆表 :数据存储无序 位图索引 ...

  10. c# 第一个实例 通哥

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...