js 객체가 dom 객체인지 확인하는 방법

高洛峰
풀어 주다: 2016-12-05 14:32:21
원래의
1343명이 탐색했습니다.

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 === &#39;object&#39; ) ?
        function(obj){
          return obj instanceof HTMLElement;
        } :
        function(obj){
          return obj && typeof obj === &#39;object&#39; && obj.nodeType === 1 && typeof obj.nodeName === &#39;string&#39;;
        }
  </script>
로그인 후 복사


관련 라벨:
js
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿