Heim > Web-Frontend > js-Tutorial > Wie wähle ich HTML-Elemente nach Klassennamen in JavaScript aus?

Wie wähle ich HTML-Elemente nach Klassennamen in JavaScript aus?

Patricia Arquette
Freigeben: 2024-11-07 14:01:03
Original
549 Leute haben es durchsucht

How to Select HTML Elements by Class Name in JavaScript?

Wie erhalte ich ElementByClass mit JavaScript?

Frage:

Sie möchten die Sichtbarkeit umschalten von DIV-Elementen basierend auf ihrer Klasse mithilfe eines JavaScript-Snippets. Das aktuelle Skript basiert jedoch auf getElementById, was nicht geeignet ist, da die DIV-Namen dynamisch mithilfe von XSLT generiert werden.

Antwort:

getElementsByClassName-Methode:

Moderne Browser unterstützen nativ die Methode getElementsByClassName. Sie können die Verfügbarkeit prüfen und sie verwenden, wenn sie unterstützt wird.

Dustin-Diaz-Methode (für ältere Browser):

Verwenden Sie für ältere Browser die Dustin-Diaz-Methode:

<code class="javascript">function getElementsByClassName(node, classname) {
  if (node.getElementsByClassName) { // Native implementation exists
    return node.getElementsByClassName(classname);
  } else {
    return (function getElementsByClass(searchClass, node) {
        if ( node == null )
          node = document;
        var classElements = [],
            els = node.getElementsByTagName("*"),
            elsLen = els.length,
            pattern = new RegExp("(^|\s)"+searchClass+"(\s|$)"), i, j;

        for (i = 0, j = 0; i < elsLen; i++) {
          if ( pattern.test(els[i].className) ) {
              classElements[j] = els[i];
              j++;
          }
        }
        return classElements;
    })(classname, node);
  }
}
Nach dem Login kopieren

Aktualisiertes Umschaltskript:

Verwenden Sie die getElementsByClassName-Methode oder den Dustin Diaz-Fallback in Ihrem Umschaltskript:

<code class="javascript">function toggle_visibility(className) {
   var elements = getElementsByClassName(document, className),
       n = elements.length;
   for (var i = 0; i < n; i++) {
     var e = elements[i];

     if(e.style.display == 'block') {
       e.style.display = 'none';
     } else {
       e.style.display = 'block';
     }
  }
}
Nach dem Login kopieren

Verwendung :

Ändern Sie in Ihrem HTML die Onclick-Attribute Ihrer Toggle-Links, um auf die neue Funktion toggle_visibility zu verweisen:

<code class="html"><a href="#" onclick="toggle_visibility('class1');">Click here to toggle visibility of class 1 objects</a>
<a href="#" onclick="toggle_visibility('class2');">Click here to toggle visibility of class 2 objects</a></code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie wähle ich HTML-Elemente nach Klassennamen in JavaScript aus?. 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