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 相关文章推荐
通过MSXML2自动获取QQ个人头像及在线情况(给初学者)
Jan 22 Javascript
Autocomplete Textbox Example javascript实现自动完成成功
Aug 17 Javascript
jquery对ajax的支持介绍
Dec 10 Javascript
JS去除字符串两端空格的简单实例
Dec 27 Javascript
JavaScript生成福利彩票双色球号码
May 15 Javascript
win7下安装配置node.js+express开发环境
Dec 06 Javascript
JavaScript驾驭网页-DOM
Mar 24 Javascript
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Dec 14 Javascript
利用Javascript开发一个二维周视图日历
Dec 14 Javascript
JavaScript函数定义方法实例详解
Mar 05 Javascript
vue使用axios上传文件(FormData)的方法
Apr 14 Javascript
Javascript摸拟自由落体与上抛运动原理与实现方法详解
Apr 08 Javascript
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
通过dbi使用perl连接mysql数据库的方法
2014/04/16 PHP
php数据访问之增删改查操作
2016/05/09 PHP
小型js框架veryide.librar源代码
2009/03/05 Javascript
Jquery下attr和removeAttr的使用方法
2010/12/28 Javascript
提高jQuery性能的十个诀窍
2013/11/14 Javascript
排序算法的javascript实现与讲解(99js手记)
2014/09/28 Javascript
JavaScript匿名函数用法分析
2015/02/13 Javascript
详解Bootstrap创建表单的三种格式(一)
2016/01/04 Javascript
javascript和jquery实现用户登录验证
2016/05/04 Javascript
Query常用DIV操作获取和设置长度宽度的实现方法
2016/09/19 Javascript
基于bootstrap-datetimepicker.js不支持IE8的快速解决方法
2016/11/07 Javascript
Vue实现路由跳转和嵌套
2017/06/20 Javascript
vue填坑之webpack run build 静态资源找不到的解决方法
2018/09/03 Javascript
js正则取值的结果数组调试方法
2018/10/10 Javascript
Vue获取微博授权URL代码实例
2020/11/04 Javascript
python实现web方式logview的方法
2015/08/10 Python
Python实现的异步代理爬虫及代理池
2017/03/17 Python
基于循环神经网络(RNN)实现影评情感分类
2018/03/26 Python
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
Python实现把多维数组展开成DataFrame
2019/11/30 Python
python 瀑布线指标编写实例
2020/06/03 Python
Python实现加密接口测试方法步骤详解
2020/06/05 Python
如何在Windows中安装多个python解释器
2020/06/16 Python
keras分类模型中的输入数据与标签的维度实例
2020/07/03 Python
htnl5利用svg页面高斯模糊的方法
2018/07/20 HTML / CSS
美国专业级皮肤病和spa品质护肤品的高级零售网站:SkinCareRx
2017/02/06 全球购物
Dr. Martens马汀博士澳大利亚官网:马丁靴鼻祖
2019/07/02 全球购物
美国环保妈妈、儿童和婴儿用品购物网站:The Tot
2019/11/24 全球购物
装饰资料员岗位职责
2013/12/30 职场文书
安全检查与奖惩制度
2014/01/23 职场文书
优秀团队申报材料
2014/12/26 职场文书
员工辞退通知书
2015/04/17 职场文书
2015年体育教师个人工作总结
2015/05/12 职场文书
创业计划书之美甲店
2019/09/20 职场文书
python​格式化字符串
2022/04/20 Python
Python使用Opencv打开笔记本电脑摄像头报错解问题及解决
2022/06/21 Python