节点间"包含"关系的访问

判断2个节点间是否存在包含关系,即是否存在父子之间的关系,我们可以使用:
elA.contains(elB) 方法,如果elA是elB的祖先,则返回true.

//判断 <html>元素是否包含<body>元素
alert(document.documentElement.contains(document.body)); //true



IE,Chrome,Opera8+,Safari3+支持该属性,Firefox不支持该方法,不过,它提供了另外一个方法:
elA.compareDocumentPosition(elB) ,它返回一个"位掩码"来表示节点间的关系。返回值如下:

Mask含义
1无联系,elB不在elA所在的document中
2之前,elB在elA之前(DOM tree上的位置)
4之后,elB在elA之后(DOM tree上的位置)
8包含,elB包含elA
16被包含,elB被包含在elA

 

//例如:
//因为 <body>在<html>之后,且被包含,所以值为 4 + 16 = 20;
alert(document.documentElement.contains(document.body)); //20

 因此,跨浏览器的包含判断函数如下:

function contains(refNode, otherNode){
	if (typeof refNode.contains == 'function' &&
	        (!client.engine.webkit || client.engine.webkit >= 522)){
	    return refNode.contains(otherNode);
	}
	else if (typeof refNode.compareDocumentPosition == 'function'){
	        return !!(refNode.compareDocumentPosition(otherNode) & 16);
	}
	else {
	    var node = otherNode.parentNode;
	    do {
	        if (node === refNode){
	            return true;
	        } else {
	            node = node.parentNode;
	        }
	    } while (node !== null);
	    return false;
	}
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值