码迷,mamicode.com
首页 > 编程语言 > 详细

javascript判断对象是否为domElement

时间:2019-03-31 09:43:41      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:nbsp   ===   dom   chrome   ==   比较   class   使用   level   

我们在写js代码时有时需要判断某个对象是不是DOM对象,然后再进行后续的操作,这里我给出一种兼容各大浏览器,同时又算是比较稳妥的一种方法。

要判断一个对象是否DOM对象,首先想到的无非就是它是否具有DOM对象的各种属性或特征,比如是否有nodeType属性,有tagName属性,等等。判断的特征越多,也就越可靠,因为毕竟我们自定义的js对象也可以有那些属性。还有其他方法吗?

在DOM Level2标准中定义了一个HTMLElement对象,它规定所有的DOM对象都是HTMLElement的实例,所以我们可以利用这点来判断一个对象是不是DOM对象:如果该对象是HTMLElement的实例,则它肯定是一个DOM对象。在不支持HTMLElement的浏览器中我们则还是使用特征检测法。
 

<script type="text/javascript">
//首先要对HTMLElement进行类型检查,因为即使在支持HTMLElement
//的浏览器中,类型却是有差别的,在Chrome,Opera中HTMLElement的
//类型为function,此时就不能用它来判断了
var isDOM = ( typeof HTMLElement === object ) ?
function(obj){
return obj instanceof HTMLElement;
} :
function(obj){
return obj && typeof obj === object && (obj.nodeType === 1 || obj.nodeType === 9) && typeof obj.nodeName === string;
}
</script>

 

改写

function isElement(obj){
return (typeof HTMLElement === ‘object‘) 
?(obj instanceof HTMLElement)
:!!(obj && typeof obj === ‘object‘ && (obj.nodeType === 1 || obj.nodeType === 9) && typeof obj.nodeName === ‘string‘);
}

 

javascript判断对象是否为domElement

标签:nbsp   ===   dom   chrome   ==   比较   class   使用   level   

原文地址:https://www.cnblogs.com/7qin/p/10630088.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!