js 코드를 작성할 때 후속 작업을 수행하기 전에 객체가 DOM 객체인지 확인해야 하는 경우가 있습니다. 여기서는 주요 브라우저와 호환되고 비교적 안전한 방법을 제공합니다.
객체가 DOM 객체인지 판단하기 위해 가장 먼저 생각해야 할 것은 DOM 객체의 다양한 속성이나 특성(예: nodeType 속성, tagName 속성 등)을 가지고 있는지 여부입니다. . 판단되는 기능이 많을수록 더 신뢰할 수 있습니다. 왜냐하면 결국 우리의 사용자 정의 js 객체도 그러한 속성을 가질 수 있기 때문입니다. 다른 방법이 있습니까?
HTMLElement 객체는 모든 DOM 객체가 HTMLElement의 인스턴스라고 규정하는 DOM Level2 표준에 정의되어 있으므로 이를 사용하여 객체가 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 && typeof obj.nodeName === 'string'; } </script>