Мы часто используем nodeType==1, чтобы определить, является ли элемент элементом HMTLElement. Элементами на странице являются все узлы, включая узел элемента, узел атрибута, текстовый узел и т. д. w3c nodeType определяется следующим образом
const беззнаковый короткий ELEMENT_NODE = 1;
const беззнаковый короткий ATTRIBUTE_NODE = 2;
const беззнаковый короткий TEXT_NODE = 3;
const беззнаковый короткий CDATA_SECTION_NODE = 4;
const беззнаковый короткий ENTITY_REFERENCE_NODE = 5;
const беззнаковый короткий ENTITY_NODE = 6;
const беззнаковый короткий PROCESSING_INSTRUCTION_NODE = 7;
const беззнаковый короткий COMMENT_NODE = 8;
const беззнаковый короткий DOCUMENT_NODE = 9;
const беззнаковый короткий DOCUMENT_TYPE_NODE = 10;
const беззнаковый короткий DOCUMENT_FRAGMENT_NODE = 11;
const беззнаковый короткий NOTATION_NODE = 12;
Но что, если наш пользовательский объект также содержит атрибут nodeType? нравиться
Скопируйте код кода следующим образом:
вар объект = {nodeType:1};
функция isHTMLElement(obj){
если (obj.nodeType) {
вернуть obj.nodeType==1;
}
}
isHTMLElement(obj);//истина
Вышеупомянутый метод 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;
}поймать(е){
вернуть ложь;
}
}
вар obj1 = {nodeType:1};
var obj2 = document.createTextNode("привет");
var obj2 = document.createElement("p");
isHTMLElement(obj1);//ложь
isHTMLElement(obj2);//ложь
isHTMLElement(obj3);//истина
Окна и документы требуют особого обращения.
Скопируйте код кода следующим образом:
функция isHtmlControl(obj) {
var d = document.createElement("div");
пытаться{
d.appendChild(obj.cloneNode(true));
вернуть obj.nodeType == 1? true: false;
}поймать(е){
вернуть obj==окно || obj==документ;
}
}