[转]firefox与IE的nextSibling

本文讨论了Firefox与IE浏览器中JavaScript的兼容性问题,包括document.all与getElementById的区别、处理firstChild与nextSibling的方法及代码实现,并提及了ID大小写敏感性和NULL字符处理的差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文转自:http://ailantian.bokee.com/6418694.html

原文如下:

网上firefox和ie的javascript兼容性也讲的比较多了
可以在百度上搜索"firefox javascript 兼容性"
比较简单的东西百度上能找到中文的就用baidu好了.
主要一般都是document.all这样的应用,一般改为getElementById
还有就是一个页面有多个表单的时候需要注意一些问题.

下面还有一些需要补充的
就是firstChild,nextsbiling这两个.
下面给出函数吧.还是代码比较说明问题
代码都是网上来的.
不过要注意的是,getNext和getFirstChild是不一样的
next是下一个,同级别的下一个,不会取到自己这个节点的子节点.

可能是因为对dom的理解不一样ie和firefox对firstChild,nextSbiling的处理不太一样.
所以要取到下一个结点,只能用type来判断了.


function getNextSibling(startBrother){
endBrother=startBrother.nextSibling;
while(endBrother.nodeType!=1){
endBrother = endBrother.nextSibling;
}
return endBrother;
}

function getNextSibling1(obj){
if(obj.nextSibling.nodeType==3) {
sibling=obj.nextSibling.nextSibling; // Moz. Opera
}
else {
sibling=obj.nextSibling; // IE
}
return sibling;
}
function getFirstChild(obj){
for (i=0; i<obj.childNodes.length; i++){
if (obj.childNodes[i].nodeType==1)
return obj.childNodes[i];
else
continue;
}

需要使用的时候先getElementByid获取到首结点,然后就可以取到后面的结点了.


另外就是ie不区分变量大小写,收到html首先就格式化了,所以要注意id可能会相同.
会导致一些问题.

另外就是ie会把NULL字符转换成space空格,firefox是不会处理的,但是
如果javascript里面处理NULL会有一些问题.opera基本能够兼容IE的一些
函数,比如documnet.all等等.基本都能用吧,不过空字符还是不行的.是变量中的空字符
会带来问题.


"Cannot read properties of null (reading 'nextSibling')"这个错误通常是因为尝试在一个值为null的对象上访问属性或方法而导致的。根据你提供的引用,这个错误可能HTML/XML节点操作有关。 在IE中,nextSibling属性不会返回文本节点,而在Chrome或Firefox等其他浏览器中会返回文本节点。这意味着,在使用nextSibling属性时,如果下一个节点是文本节点,那么在IE中可能会遇到null值的情况。因此,当你尝试在这个null值上使用nextSibling属性时,就会出现"Cannot read properties of null (reading 'nextSibling')"的错误。 另外,在el-table-column渲染时,如果scope.row.field(field为任意字段值)不存在,直接对其执行length、toString()等方法也会导致报错。这是因为当scope.row.field不存在时,它的值为null或undefined,而这些值是没有length和toString()方法的。因此,如果你尝试在不存在的字段上执行这些方法,就会出现类似的错误。 最后,当默认弹框是关闭的时,DOM中没有弹框中的内容。但是,当你打开弹框并关闭后,弹框中的DOM元素并没有被销毁,仍然存在于DOM中。如果你尝试操作这些不应该存在的DOM元素,就可能会导致类似的报错。 综上所述,"Cannot read properties of null (reading 'nextSibling')"错误可能由于在null值上访问属性或方法而导致。在HTML/XML节点操作中,特别是使用nextSibling属性、在不存在的字段上执行方法或尝试操作不应该存在的DOM元素时,请确保先进行必要的检查和验证,以避免这个错误的发生。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值