Heim >Web-Frontend >js-Tutorial >Jquery-Kontrollkästchen überprüfte Fehlerproblemlösung und Analyse_jquery

Jquery-Kontrollkästchen überprüfte Fehlerproblemlösung und Analyse_jquery

WBOY
WBOYOriginal
2016-05-16 16:31:281297Durchsuche

Als ich an einem Projekt arbeitete, stieß ich auf einen Fehler im jQuery-Checkbox-Kontrollkästchen. Nachdem ich mich mit einem Master beraten hatte, habe ich es hier aufgezeichnet und für alle analysiert.

Geben Sie zunächst den Code ein:

Code kopieren Der Code lautet wie folgt:


​ ​ ​ Was ist dein Lieblingssport? Alle auswählen/Alle auswählen

           football
           Basketball
            Badminton
           Tischtennis
          

        

Code kopieren Der Code lautet wie folgt:

$("#CheckedAll").click(function () {
If ($(this).is(":checked")) {
$("[name=items]:checkbox").attr("checked", true);
                    } sonst {
                                 $("[name=items]:checkbox").attr("checked", false);
                }
            });

Als ich es zum ersten Mal ausführte, gab es kein Problem, aber als ich es zum zweiten Mal ausführte, gab es ein Problem und ich konnte mich nicht entscheiden

Lösung: Ersetzen Sie attr() durch prop()

Code kopieren Der Code lautet wie folgt:

$("#CheckedAll").click(function () {
If ($(this).is(":checked")) {
                            $("[name=items]:checkbox").prop("checked", true);
                    } sonst {
                              $("[name=items]:checkbox").prop("checked", false);
                }
            });

PS: Der Unterschied zwischen prop() und attr():

Ich habe kürzlich in den Nachrichten von iteye gesehen, dass jQuery auf 1.6.1 aktualisiert wurde. Die größte Änderung gegenüber der Vorgängerversion ist die Hinzufügung der .prop-Methode. Es ist jedoch schwierig, buchstäblich zwischen der .prop()-Methode und der .attr()-Methode zu unterscheiden. Im Chinesischen bedeuten Eigenschaften und Attribute beide „Attribute“.
Das Folgende ist eine kurze Übersetzung der Verwendung von .prop() und .attr() basierend auf diesem Blogbeitrag (javascript:mctmp(0);):

1. Upgrade von 1.5.2 auf 1.6.1

Mit der Einführung der neuen Methode .prop() und den Änderungen an der Methode .attr() löste jQuery 1.6.1 eine hitzige Diskussion über die Unterschiede und Zusammenhänge zwischen Attributen und Eigenschaften aus. Gleichzeitig löst 1.6.1 auch einige Probleme mit der Abwärtskompatibilität. Beim Upgrade von 1.5.2 auf 1.6.1 müssen Sie keinen Attributcode ändern.

Im Folgenden finden Sie eine Beschreibung der Änderungen im Attributes-Modul in jQuery 1.6 und 1.6.1 sowie der bevorzugten Verwendung der .attr()-Methode und der .prop()-Methode. Wie bereits erwähnt, können Sie mit jQuery 1.6.1 jedoch die Methode .attr() verwenden, wie sie in allen Fällen zuvor verwendet wurde.

2. Welche Änderungen sind aufgetreten

Die Änderung am Attributes-Modul sollte die Mehrdeutigkeit zwischen Attributen und Eigenschaften beseitigen, verursachte jedoch einige Verwirrung in der jQuery-Community, da in allen Versionen vor 1.6 Attribute und Eigenschaften mit einer einzigen Methode (.attr()) verarbeitet wurden. Aber die alte .attr()-Methode weist einige Fehler auf und ist schwer zu warten. jQuery1.6.1 aktualisiert das Attributes-Modul und behebt mehrere Fehler.

Besonders zu erwähnen ist, dass boolesche Attribute wie „geprüft“, „ausgewählt“, „schreibgeschützt“ und „deaktiviert“ in 1.6.1 genauso behandelt werden wie vor 1.6. Damit ist folgender Code gemeint:

Code kopieren Der Code lautet wie folgt:

$(“:checkbox”).attr(“checked”, true); $(„option“).attr(„selected“, true); $(“input”).attr(“readonly”, true); $(“input”).attr(“disabled”, true);


Sogar Code wie dieser:

Code kopieren

Der Code lautet wie folgt: if ( $(“:checkbox”).attr(“checked”) ) { /* Etwas tun */ }

In 1.6.1 sind keine Änderungen erforderlich, um die zuvor erwartete Leistung aufrechtzuerhalten.
Um die Änderungen in der .attr()-Methode in jQuery 1.6 klarer zu machen, finden Sie hier einige Beispiele für die Verwendung von .attr(). Obwohl es in früheren Versionen von jQuery normal funktionieren kann, muss es jetzt verwendet werden ()-Methode stattdessen:

Erstens funktioniert die Verwendung der Methode .attr() in Fenstern oder Dokumenten in jQuery 1.6 nicht ordnungsgemäß, da in Fenstern und Dokumenten keine Attribute vorhanden sein können. Sie enthalten Eigenschaften (z. B. location oder readyState) und müssen mit der Methode .prop() oder einfach mit nativen JavaScript-Methoden manipuliert werden. In jQuery 1.6.1 wird die Verwendung von .attr() in Fenster und Dokument automatisch in die Verwendung von .prop konvertiert, anstatt einen Fehler auszulösen.

Zweitens werden geprüfte, ausgewählte und andere zuvor erwähnte boolesche Attribute aufgrund der besonderen Beziehung zwischen diesen Attributen und ihren entsprechenden Eigenschaften besonders behandelt. Im Grunde ist ein Attribut das, was Sie im folgenden HTML-Code sehen:

Boolesche Attribute wie „checked“ werden nur auf Standard- oder Anfangswerte gesetzt. In einem Checkbox-Element werden aktivierte Attribute beim Laden der Seite festgelegt, unabhängig davon, ob das Checkbox-Element ausgewählt ist.

Eigenschaften sind das, was der Browser verwendet, um den aktuellen Wert aufzuzeichnen. Normalerweise spiegeln Eigenschaften ihre entsprechenden Attribute wider (falls vorhanden). Dies ist jedoch bei booleschen Attributen nicht der Fall. Boolesche Eigenschaften werden auf dem neuesten Stand gehalten, wenn der Benutzer auf ein Kontrollkästchenelement klickt oder eine Option in einem Auswahlelement auswählt. Die entsprechenden booleschen Attribute sind jedoch unterschiedlich. Wie oben erwähnt, werden sie vom Browser nur zum Speichern des Anfangswerts verwendet.



Code kopieren

In jQuery1.6, wenn Sie die folgende Methode zum Festlegen von Häkchen verwenden:



Code kopieren



Der Code lautet wie folgt:

$(“:checkbox”).attr(“checked”, true);

Das Kontrollkästchenelement wird nicht aktiviert, da es sich um eine Eigenschaft handelt, die festgelegt werden muss, aber alle Ihre Einstellungen sind Anfangswerte.

Nach der Veröffentlichung von jQuery 1.6 erkannte das jQuery-Team jedoch, dass das Festlegen einiger Werte nicht besonders nützlich war, wenn sich der Browser nur um das Laden der Seite kümmerte. Um die Abwärtskompatibilität und den Nutzen der .attr()-Methode aufrechtzuerhalten, können wir daher weiterhin die .attr()-Methode verwenden, um diese booleschen Attribute in jQuery 1.6.1 abzurufen und festzulegen.

Die häufigsten Attribute sind „geprüft“, „ausgewählt“, „deaktiviert“ und „schreibgeschützt“, aber im Folgenden finden Sie die vollständige Liste der von jQuery 1.6.1 unterstützten Verwendung von .attr() zum dynamischen Abrufen und Festlegen boolescher Attribute/Eigenschaften:

Autofokus, automatische Wiedergabe, asynchron, aktiviert, steuert, verzögert, deaktiviert,
versteckt, Schleife, mehrfach, offen, schreibgeschützt, erforderlich, bereichsbezogen, ausgewählt

(Anmerkung des Übersetzers: Die meisten davon sind neue Attribute, die zu HTML5 hinzugefügt wurden)

Es wird weiterhin empfohlen, die .prop()-Methode zum Festlegen dieser booleschen Attribute/Eigenschaften zu verwenden. Auch wenn diese Anwendungsfälle nicht für die Verwendung der .prop()-Methode konvertiert werden, kann Ihr Code weiterhin normal in jQuery 1.6 ausgeführt werden. 1.

Im Folgenden finden Sie eine Liste einiger Attribute und Eigenschaften. Unter normalen Umständen sollten Sie die entsprechenden Methoden (siehe Liste unten) verwenden, um sie abzurufen und festzulegen. Das Folgende ist die erste Verwendung, aber die Methode .attr() funktioniert mit allen Attributen.

Hinweis: Einige DOM-Elementeigenschaften sind ebenfalls unten aufgeführt, werden jedoch nur in der neuen .prop()-Methode

ausgeführt

*Zum Beispiel: window.location
**Bei Bedarf über (bei Bedarf über) .width()

Weder .attr() noch .prop() sollten zum Abrufen/Festlegen von Werten verwendet werden. Verwenden Sie stattdessen die Methode .val() (selbst die Verwendung von .attr("value","somevalue") funktioniert weiterhin, genau wie vor 1.6)

3. Übersicht über die bevorzugte Nutzung

Die Methode

.prop() sollte verwendet werden, um boolesche Attribute/Eigenschaften und Eigenschaften zu verarbeiten, die in HTML nicht vorhanden sind (z. B. window.location). Alle anderen Attribute (die Sie in HTML sehen) können und sollten weiterhin mit der Methode .attr() manipuliert werden.

Die obige Zusammenfassung wurde klar genug beschrieben und es besteht für mich keine Notwendigkeit, sie weiter zusammenzufassen.

Stellungnahme:
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