zoukankan      html  css  js  c++  java
  • Dom操作之兼容技巧

    在使用Dom操作HTML和XML时.我们时常会遇到空格问题.或许你还没有遇到过.例如:我们在获取ul下所有li元素的时候.或者是某个元素的下一个元素时.都有可能会碰到这讨厌的空格问题.当然在IE浏览器里这些空格会被自动过滤.而FF则没有那么勤劳.FF浏览器会把这些空格也看作为一个元素.如果你对Dom中的空格元素感到疑惑,请运行下面的代码.至少使用IE和FF两种浏览器测试.你会明白一切!

    <!DOCTYPE HTML>
    <html>
    <head>
    <meta charset="utf-8">
    <title>Dom</title>
    </head>
    <body>
    <h2>运行该代码以后.你会发现在IE里弹出3.在FF里弹出7.</h2>
    <ol id="list">
    <li>html</li>
    <li>css</li>
    <li>dom</li>
    </ol>
    <script>
    var list = document.getElementById("list");
    var list_child = list.childNodes; //获取ol中所有的子元素
    alert("ol中共有"+list_child.length+"个元素,分别是");
    for(var i = 0; i<list_child.length; i++){
    alert(list_child[i].tagName);
    }
    </script>
    </body>
    </html>

    上面的代码演示了要获取ol元素中所有的子元素.并弹出ol内有几个子元素.我们可以看到ol中包含了3个li元素.在IE中弹出3这是正确的.那为什么到了FF和Chrome浏览器中会弹出7呢? 其实在你书写代码的时候.在元素与元素换行之间都会形成一个空格.(注意:不要以为回一次车就会形成一个空格.这是错误的,也就是说元素与元素之间的空白,你就是换几百次行.也算一个空格)FF和Chrome浏览器不会过滤这些空格元素.所以弹出7也是正确的. 
    下面我们用同样的html结构.来演示如何过滤删除这些空格元素.

    <!DOCTYPE HTML>
    <html>
    <head>
    <meta charset="utf-8">
    <title>Dom</title>
    </head>
    <body>
    <h2>运行该代码以后.你会发现在IE,FF,Chrome里返回的结果一样了.</h2>
    <ol id="list">
    <li>html</li>
    <li>css</li>
    <li>dom</li>
    </ol>
    <script>
    function Del_space(elem){ //过滤空格的函数
       var elem_child = elem.childNodes; //获取所有子元素
       for(var i = 0;i<elem_child.length;i++){
           //如果是文本节点,并且内容只包含空格则删除该节点
           if(elem_child[i].nodeName == "#text" && ! /\S/.test(elem_child[i].nodeValue)){
               elem.removeChild(elem_child[i]);//如果该元素为空格则删除
           }
       }
    }
    Del_space(document.getElementById("list")); //删除ol中的所有空格
    var list = document.getElementById("list");
    var list_child = list.childNodes; //获取ol中所有的子元素
    for(var i=0;i<list_child.length;i++){
        alert(list_child[i].tagName);
    }
    </script>
    </body>
    </html>
    

    推荐如下方法:

    <!DOCTYPE HTML>
    <html>
    <head>
    <meta charset="utf-8">
    <title>Dom</title>
    </head>
    <body>
    <h2>运行该代码以后.你会发现在IE,FF,Chrome里返回的结果一样了.</h2>
    <ol id="list">
    <li>html</li>
    <li>css</li>
    <li>dom</li>
    </ol>
    <script>
    for(var x=0,list_li = document.getElementById('list').childNodes; x<list_li.length; x++){
    	if(list_li[x].nodeType == 1){
    		alert(list_li[x].tagName);
    	}
    }
    </script>
    </body>
    </html>
    



  • 相关阅读:
    sql分页查询
    vi编辑器使用
    Linux命令:
    ubuntu中mysql忘记密码如何修改
    关于MySQL中自增的理解和设置
    MySQL中是索引
    MySQL中的分页操作结合python
    MySQL的分组和排序
    MySQL多表连接操作
    .NET Core App部署Linux
  • 原文地址:https://www.cnblogs.com/radom/p/2181979.html
Copyright © 2011-2022 走看看