欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Dom操作之兼容技巧分享

程序员文章站 2022-10-14 22:06:30
例如:我们在获取ul下所有li元素的时候.或者是某个元素的下一个元素时.都有可能会碰到这讨厌的空格问题.当然在ie浏览器里这些空格会被自动过滤.而ff则没有那么勤劳.ff浏...
例如:我们在获取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>
相关标签: Dom操作 兼容