Dom操作之兼容技巧分享


Posted in Javascript onSeptember 20, 2011

例如:我们在获取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>
Javascript 相关文章推荐
让页面上两个div中的滚动条(滑块)同步运动示例
Aug 07 Javascript
基于jQuery实现的美观星级评论打分组件代码
Oct 30 Javascript
Bootstrap布局组件应用实例讲解
Feb 17 Javascript
jQuery中DOM节点的删除方法总结(超全面)
Jan 22 Javascript
js时间戳格式化成日期格式的多种方法介绍
Feb 16 Javascript
jQuery操作css样式
May 15 jQuery
react-router中的属性详解
Jun 01 Javascript
详解利用 Express 托管静态文件的方法
Sep 18 Javascript
echarts实现地图定时切换散点与多图表级联联动详解
Aug 07 Javascript
详解Angular5/Angular6项目如何添加热更新(HMR)功能
Oct 10 Javascript
React Hooks的深入理解与使用
Nov 12 Javascript
Vue中ref和$refs的介绍以及使用方法示例
Jan 11 Vue.js
js获取图片大小的函数代码
Sep 20 #Javascript
javascript中的注释使用与注意事项小结
Sep 20 #Javascript
70+漂亮且极具亲和力的导航菜单设计国外网站推荐
Sep 20 #Javascript
JavaScript高级程序设计 学习笔记 js高级技巧
Sep 20 #Javascript
跨浏览器通用、可重用的选项卡tab切换js代码
Sep 20 #Javascript
JQuyer $.post 与 $.ajax 访问WCF ajax service 时的问题需要注意的地方
Sep 20 #Javascript
简单的jquery拖拽排序效果实现代码
Sep 20 #Javascript
You might like
php json转换成数组形式代码分享
2014/11/10 PHP
YII框架模块化处理操作示例
2019/04/26 PHP
javascript 多浏览器 事件大全
2010/03/23 Javascript
JS 事件绑定函数代码
2010/04/28 Javascript
javascript 伪数组实现方法
2010/10/11 Javascript
浅谈JavaScript中的Math.atan()方法的使用
2015/06/14 Javascript
js实现鼠标点击文本框自动选中内容的方法
2015/08/20 Javascript
多种js图片预加载实现方式分享
2016/02/19 Javascript
xmlplus组件设计系列之分隔框(DividedBox)(8)
2017/05/02 Javascript
解决React Native端口号修改的方法
2017/07/28 Javascript
vue2.0使用swiper组件实现轮播效果
2017/11/27 Javascript
Vue常用的全选/反选的示例代码
2020/02/19 Javascript
基于javascript canvas实现五子棋游戏
2020/07/08 Javascript
JS创建自定义对象的六种方法总结
2020/12/15 Javascript
微信小程序实现登录注册功能
2020/12/29 Javascript
[04:49]期待西雅图之战 2016国际邀请赛中国区预选赛WINGS战队赛后采访
2016/06/29 DOTA
轻松实现python搭建微信公众平台
2016/02/16 Python
wxPython实现窗口用图片做背景
2018/04/25 Python
Python使用pickle模块实现序列化功能示例
2018/07/13 Python
详解用python实现基本的学生管理系统(文件存储版)(python3)
2019/04/25 Python
python kafka 多线程消费者&amp;手动提交实例
2019/12/21 Python
Python实现点云投影到平面显示
2020/01/18 Python
PyTorch笔记之scatter()函数的使用
2020/02/12 Python
Python中私有属性的定义方式
2020/03/05 Python
python3:excel操作之读取数据并返回字典 + 写入的案例
2020/09/01 Python
CSS3中线性颜色渐变的一些实现方法
2015/07/14 HTML / CSS
BOSE德国官网:尽探索之力,享音乐之极
2016/12/11 全球购物
新加坡网上美容店:Hermo新加坡
2019/06/19 全球购物
新闻编辑自荐信
2013/11/03 职场文书
学校食堂采购员岗位职责
2013/12/05 职场文书
课堂教学改革实施方案
2014/03/17 职场文书
合作意向书范本
2014/03/31 职场文书
selenium.webdriver中add_argument方法常用参数表
2021/04/08 Python
再也不用花钱买漫画!Python爬取某漫画的脚本及源码
2021/06/09 Python
Java 超详细讲解IO操作字节流与字符流
2022/03/25 Java/Android
《进击的巨人》新联动CM 兵长强势出击兽巨人
2022/04/05 日漫