Heim > Web-Frontend > js-Tutorial > Wie kann man zuverlässig feststellen, ob ein JavaScript-Objekt ein DOM-Element ist?

Wie kann man zuverlässig feststellen, ob ein JavaScript-Objekt ein DOM-Element ist?

Mary-Kate Olsen
Freigeben: 2024-10-27 07:08:03
Original
650 Leute haben es durchsucht

How to Reliably Determine if a JavaScript Object is a DOM Element?

So ermitteln Sie den DOM-Objektstatus in JavaScript

In JavaScript ist die Unterscheidung zwischen DOM-Objekten (Document Object Model) und regulären JavaScript-Objekten von entscheidender Bedeutung für bestimmte Operationen. Während der herkömmliche Ansatz der Überprüfung der tagName-Eigenschaft in den meisten Fällen funktioniert, kann er in einigen Browsern fehlschlagen, die keine schreibgeschützten Eigenschaften erzwingen.

Eine umfassende Lösung

Um dieses Problem zu beheben, ziehen Sie die folgende Funktion in Betracht:

<code class="javascript">function isElement(obj) {
  try {
    // W3 DOM2 (works for FF, Opera, and Chrome)
    return obj instanceof HTMLElement;
  } catch (e) {
    // Non-DOM2 browsers
    return (
      typeof obj === 'object' &&
      obj.nodeType === 1 &&
      typeof obj.style === 'object' &&
      typeof obj.ownerDocument === 'object'
    );
  }
}</code>
Nach dem Login kopieren

Dieser Code nutzt W3 DOM2 für unterstützte Browser und prüft auf bestimmte Eigenschaften in Nicht-DOM2-Browsern.

Zusätzliche Optionen

Ein anderer Ansatz ist die Verwendung des folgenden Codes:

<code class="javascript">function isNode(o) {
  return typeof Node === 'object'
    ? o instanceof Node
    : o &&
        typeof o === 'object' &&
        typeof o.nodeType === 'number' &&
        typeof o.nodeName === 'string';
}

function isElement(o) {
  return typeof HTMLElement === 'object'
    ? o instanceof HTMLElement
    : o &&
        typeof o === 'object' &&
        o !== null &&
        o.nodeType === 1 &&
        typeof o.nodeName === 'string';
}</code>
Nach dem Login kopieren

Dieser Code unterscheidet zwischen DOM-Knoten und Elementen und berücksichtigt mögliche Unterschiede in Browser-Implementierungen.

Das obige ist der detaillierte Inhalt vonWie kann man zuverlässig feststellen, ob ein JavaScript-Objekt ein DOM-Element ist?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage