当前位置: 首页 > 图文教程 > 网络编程 > Javascript > 取得父标签

Javascript
非常不错的不间断循环滚动类 兼容多浏览器
完美解决JS中汉字显示乱码问题(已解决)
另类调用flash无须激活的方法
fromCharCode和charCodeAt 方法
JavaScript方法和技巧大全
选择与取消选择不错的应用 js
javascript中对对层的控制
通过js脚本复制网页上的一个表格的不错实现方法
JavaScript数组的快速克隆(slice()函数)和数组的排序、乱序和搜索(sort()函数)
slice函数的用法 之不错的应用
js自带函数备忘 数组
JavaScript 参考教程
经典的解除许多网站无法复制文字的绝招
利用JS获取IE客户端IP及MAC的实现好象不可以
彻底搞懂JS无缝滚动代码
关于Javascript 的 prototype问题。
关于JavaScript的gzip静态压缩方法
JavaScript的目的分析
智能表格
javascript中的对象和数组的应用技巧

Javascript 中的 取得父标签


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-12   浏览: 139 ::
收藏到网摘: n/a

取得父标签
FF 下没有 event
用 arguments[0]
FF 下没有 srcElement
用 target
FF 下没有 parentElement
用 parentNode
复制代码 代码如下:

function obj_event_onsomething(e){
var e=window.event?window.event:e;
var srcEle=e.srcElement?e.srcElement:e.target;
var theObjectYouWant=srcEle.parentNode;
}

刚刚又发现,FF下的childNodes比IE下的要大1
复制代码 代码如下:
o.previousSibling.href || o.previousSibling.previousSibling.href
前面一个表达式用于IE下,后面一个用于FireFox下.
因为在IE下,XMLDom没有preserveWhiteSpace这个属性,即:把空白也当作一个节点,而IE则默认为false,即把空白不看成一个节点.
这里说到了XMLDom,似乎和上面所说的不相关,但是在FireFox下 previousSibling就是空白,除非两个HTML标签之间没有任何形式的空格.

这个空白指的是 #text 节点
复制代码 代码如下:
<div>
<a>123</a>
6546
<b>321</b>
</div>

这里 div 应该有5个子节点
1. div 标记后到 a 标记前的那个回车换行
2. a 标记
3. \r\n6546\r\n
4. b 标记
5. b 标记后到 div 结束标记前的那个回车换行