Wir verwenden häufig nodeType==1, um zu bestimmen, ob ein Element ein HMTLElement-Element ist. Die Elemente auf der Seite sind alle Knoten, einschließlich Elementknoten, Attributknoten, Textknoten usw. w3c nodeType ist wie folgt definiert
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 unsigned 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;
Was aber, wenn unser benutzerdefiniertes Objekt auch das Attribut „nodeType“ enthält? wie
Kopieren Sie den Codecode wie folgt:
var obj = {nodeType:1};
Funktion isHTMLElement(obj){
if(obj.nodeType){
return obj.nodeType==1;
}
}
isHTMLElement(obj);//true
Das obige isHTMLElement(obj) gibt true zurück, aber obj ist offensichtlich kein HTML-Knotenelement. Das Folgende wird anhand von Objekteigenschaften und Try-Catch-Anweisungen beurteilt.
Kopieren Sie den Codecode wie folgt:
Funktion isHTMLElement(obj){
var d = document.createElement("div");
versuchen{
d.appendChild(obj.cloneNode(true));
return obj.nodeType==1?true:false;
}catch(e){
return false;
}
}
var obj1 = {nodeType:1};
var obj2 = document.createTextNode("hello");
var obj2 = document.createElement("p");
isHTMLElement(obj1);//false
isHTMLElement(obj2);//false
isHTMLElement(obj3);//true
Für Fenster und Dokument ist eine besondere Behandlung erforderlich.
Kopieren Sie den Codecode wie folgt:
Funktion isHtmlControl(obj) {
var d = document.createElement("div");
versuchen{
d.appendChild(obj.cloneNode(true));
return obj.nodeType==1 ? true : false;
}catch(e){
return obj==window ||. obj==document;
}
}