HTML Gegeben: so etwas zu tunWie rufen Sie die Klasse ab, um die Schaltfläche auszublenden?
<button id="buttonId1" class="hello universe">
<button id="buttonId2" class="hello world">
Was ist der richtige Weg ist:
$("#buttonId1").click(function()
{
alert($("#buttonId1").getClass());
}
Ich weiß, die getClass
Funktion nicht in JQuery oder Javascript nicht vorhanden ist. Aber ich hoffe, dass es einen Weg gibt, sich dem anzunähern. Ich habe ein komplexeres Problem in der realen Welt, das schwierig in eine einfache Frage zu reduzieren, aber im Grunde denke ich muss ich irgendwie auf die Klasse eines Elements zugreifen und dann diese Klassenzeichenfolge verwenden, um eine zusätzliche Auswahl wie folgt durchzuführen:
$(("#buttonId1").getClass().filter("world")).hide();
Vielleicht gibt es einfachere Möglichkeiten, die buttonId2
in dem Code zu verstecken, den ich gegeben habe - das ist nicht wirklich der Punkt, obwohl. Was mich interessiert, ist, wie ich in die Klasse komme und sie dann weiter benutze. Die einzige Lösung, die ich bisher gefunden habe, ist eine lange Verzweigung von if/else-Anweisungen, die alle möglichen Klassen mit der hasClass
-Funktion überprüft. Aber es ist eine sehr unelegante Lösung.
EDIT: Als Reaktion auf Paolo Antwort, vielleicht so etwas wie dies funktionieren wird button2 verstecken:
$(("#buttonId1").attr('class')[0].filter("world")).hide();
Ich möchte die Klasse verwenden ‚Hallo‘, das ist geteilt durch beide Tasten, um button2 zu verbergen. Um dies zu tun, müsste ich auch nach der Klasse 'world' filtern, die button2 hat, aber button1 nicht. Danke für den Tipp über $ (this). –
korrigieren Sie mich, wenn ich falsch liege, aber attr ('Klasse') wird ein Array zurückgeben, keine Zeichenkette ... da sind zwei Klassen aufgelistet: '[" Hallo "," Welt "]' Also die nächste Frage ist welche ein? – DGM
Ja, ich müsste das erste Element des attr ('class') - Arrays abrufen und dieses dann im Filter auf das zweite Element anwenden. Klingt klatschig, ich weiß. –