요소가 HMTLEment 요소인지 확인하기 위해 nodeType==1을 자주 사용합니다. 페이지의 요소는 요소 노드, 속성 노드, 텍스트 노드 등을 포함한 모든 노드입니다. w3c nodeType은 다음과 같이 정의됩니다.
const unsigned short ELEMENT_NODE = 1;
const unsigned short ATTRIBUTE_NODE = 2;
const unsigned short TEXT_NODE = 3;
const unsigned short CDATA_SECTION_NODE = 4;
const 부호 없는 short ENTITY_REFERENCE_NODE = 5;
const unsigned short ENTITY_NODE = 6;
const unsigned short PROCESSING_INSTRUCTION_NODE = 7;
const unsigned short COMMENT_NODE = 8;
const unsigned short DOCUMENT_NODE = 9;
const unsigned short DOCUMENT_TYPE_NODE = 10;
const unsigned short DOCUMENT_FRAGMENT_NODE = 11;
const unsigned short NOTATION_NODE = 12;
하지만 사용자 정의 객체에 nodeType 속성도 포함되어 있다면 어떻게 될까요? 좋다
다음과 같이 코드 코드를 복사합니다.
var obj = {nodeType:1};
함수 isHTMLElement(obj){
if(obj.nodeType){
return obj.nodeType==1;
}
}
isHTMLElement(obj);//true
위의 isHTMLElement(obj)는 true를 반환하지만 obj는 분명히 HTML 노드 요소가 아닙니다. 다음은 객체 특성과 try-catch 문으로 판단됩니다.
다음과 같이 코드 코드를 복사합니다.
함수 isHTMLElement(obj){
var d = document.createElement("div");
노력하다{
d.appendChild(obj.cloneNode(true));
return obj.nodeType==1?true:false;
}잡기(e){
거짓을 반환;
}
}
var obj1 = {nodeType:1};
var obj2 = document.createTextNode("hello");
var obj2 = document.createElement("p");
isHTMLElement(obj1);//false
isHTMLElement(obj2);//false
isHTMLElement(obj3);//true
창과 문서에는 특별한 처리가 필요합니다.
다음과 같이 코드 코드를 복사합니다.
함수 isHtmlControl(obj) {
var d = document.createElement("div");
노력하다{
d.appendChild(obj.cloneNode(true));
return obj.nodeType==1 ? true : false;
}잡기(e){
return obj==window || obj==문서;
}
}