


Der Unterschied zwischen attr- und prop-Attributen in JS und eine Einführung in Beispiele für die Prioritätsauswahl_Grundkenntnisse
Im Vergleich zu attr ist prop in 1.6.1 neu. Beide werden aus der chinesischen Bedeutung verstanden und sind beide Methoden zum Abrufen/Festlegen von Attributen (Attribute und Eigenschaften). Allerdings kann die in Fenstern oder Dokumenten verwendete Methode .attr() vor jQuery 1.6 nicht ordnungsgemäß ausgeführt werden, da in Fenstern oder Dokumenten keine Attribute vorhanden sein können. prop entstand.
Da wir den Unterschied zwischen ihnen wissen möchten, schauen wir uns am besten ihren Quellcode an. Lassen Sie sich nicht von der Länge des Codes abschrecken:
attr: function( elem, name, value, pass ) { var ret, hooks, notxml, nType = elem.nodeType; // don't get/set attributes on text, comment and attribute nodes if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { return; } if ( pass && jQuery.isFunction( jQuery.fn[ name ] ) ) { return jQuery( elem )[ name ]( value ); } // Fallback to prop when attributes are not supported if ( typeof elem.getAttribute === "undefined" ) { return jQuery.prop( elem, name, value ); } notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); // All attributes are lowercase // Grab necessary hook if one is defined if ( notxml ) { name = name.toLowerCase(); hooks = jQuery.attrHooks[ name ] || ( rboolean.test( name ) ? boolHook : nodeHook ); } if ( value !== undefined ) { if ( value === null ) { jQuery.removeAttr( elem, name ); return; } else if ( hooks && "set" in hooks && notxml && (ret = hooks.set( elem, value, name )) !== undefined ) { return ret; } else { elem.setAttribute( name, value + "" ); return value; } } else if ( hooks && "get" in hooks && notxml && (ret = hooks.get( elem, name )) !== null ) { return ret; } else { ret = elem.getAttribute( name ); // Non-existent attributes return null, we normalize to undefined return ret === null ? undefined : ret; } }
Prop-Methodencode (jQuery-Version 1.8.3)
prop: function( elem, name, value ) { var ret, hooks, notxml, nType = elem.nodeType; // don't get/set properties on text, comment and attribute nodes if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { return; } notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); if ( notxml ) { // Fix name and attach hooks name = jQuery.propFix[ name ] || name; hooks = jQuery.propHooks[ name ]; } if ( value !== undefined ) { if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { return ret; } else { return ( elem[ name ] = value ); } } else { if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { return ret; } else { return elem[ name ]; } } }
In der attr-Methode sind die beiden kritischsten Codezeilen elem.setAttribute(name, value „“) und ret = elem.getAttribute(name). Es ist offensichtlich, dass die Methodenoperationen setAttribute und getAttribute der DOM-API verwendet werden . Attributelementknoten.
In der Prop-Methode sind die beiden kritischsten Codezeilen return (elem[name] = value) und return elem[name]. Sie können es so verstehen: document.getElementById(el)[name] = value in JS umgewandelt Eine Eigenschaft des Objekts.
Da wir nun das Prinzip verstanden haben, werfen wir einen Blick auf ein Beispiel:
<input type="checkbox" id="test" abc="111" />
$(function(){ el = $("#test"); console.log(el.attr("style")); //undefined console.log(el.prop("style")); //CSSStyleDeclaration对象 console.log(document.getElementById("test").style); //CSSStyleDeclaration对象 });
el.attr("style") gibt undefiniert aus, da attr der Wert des Attributknotens dieses erhaltenen Objekts ist. Offensichtlich gibt es zu diesem Zeitpunkt keinen solchen Attributknoten, daher wird natürlich undefiniert ausgegeben
el.prop("style") gibt ein CSSStyleDeclaration-Objekt aus. Für ein DOM-Objekt verfügt es über native Stilobjektattribute, daher wird das Stilobjekt
ausgegeben
Was document.getElementById("test") betrifft, ist der Stil derselbe wie oben
Weiterlesen:
el.attr("abc","111") console.log(el.attr("abc")); //111 console.log(el.prop("abc")); //undefined
Verwenden Sie zunächst die Methode attr, um diesem Objekt das Knotenattribut abc mit dem Wert 111 hinzuzufügen. Sie können sehen, dass sich auch die Struktur des HTML geändert hat
Das Ausgabeergebnis von el.attr("abc") ist 111, was normal ist
el.prop("abc") gibt undefiniert aus, da sich abc in diesem Attributknoten befindet und daher nicht über prop
el.prop("abc", "222"); console.log(el.attr("abc")); //111 console.log(el.prop("abc")); //222
Wir verwenden dann die Prop-Methode, um das abc-Attribut für dieses Objekt mit einem Wert von 222 festzulegen. Sie können sehen, dass sich die Struktur des HTML nicht geändert hat. Die Ausgabeergebnisse werden nicht erklärt.
Das Prinzip wurde oben klar erklärt, Sie können selbst entscheiden, wann Sie es verwenden.
Erwähnen Sie, dass es natürlich besser ist, die Prop-Methode zu verwenden, wenn Sie Eigenschaften wie aktiviert, ausgewählt, schreibgeschützt und deaktiviert abrufen oder festlegen möchten, z. B. die folgende:
<input type="checkbox" id="test" checked="checked" />
console.log(el.attr("checked")); //checked console.log(el.prop("checked")); //true console.log(el.attr("disabled")); //undefined console.log(el.prop("disabled")); //false
Offensichtlich machen boolesche Werte die folgende Verarbeitung sinnvoller als Zeichenfolgenwerte.
PS: Wenn Sie von der JS-Leistung besessen sind, ist die Leistung von prop offensichtlich höher, da attr auf den DOM-Attributknoten zugreifen muss und der Zugriff auf das DOM am zeitaufwändigsten ist. Diese Situation gilt für Multi-Option-All-Select- und Inverse-Select-Situationen.
Jeder weiß, dass einige Browser nur „disabled“ und „checked“ schreiben müssen, während andere „disabled“ = „disabled“, „checked“ = „checked“ schreiben müssen, beispielsweise wenn attr („checked“) verwendet wird, um das geprüfte Attribut des Kontrollkästchens zu erhalten Der Wert kann abgerufen werden, wenn er ausgewählt ist. Der Wert ist „überprüft“, aber der Wert, der erhalten wird, wenn er nicht ausgewählt ist, ist undefiniert.
jq bietet eine neue Methode „prop“, um diese Attribute abzurufen, um dieses Problem zu lösen. Wenn wir in der Vergangenheit attr zum Abrufen des geprüften Attributs verwendet haben, haben wir jetzt „checked“ und „“ zurückgegeben Methode, um das Attribut abzurufen, geben wir einheitlich wahr und falsch zurück.
Also, wann sollte man attr() und wann prop() verwenden?
1. Fügen Sie den Attributnamen hinzu und das Attribut wird wirksam. Sie sollten prop();
verwenden
2. Es gibt zwei Attribute, wahr und falsch, die prop();
verwenden
3. Für andere verwenden Sie attr();
Darauf sollte jeder achten, wenn er jquery im Projekt aktualisiert!
Im Folgenden finden Sie offizielle Empfehlungen für die Verwendung von attr() und prop():
Im Folgenden finden Sie offizielle Empfehlungen für die Verwendung von attr() und prop():

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen
![So beheben Sie den Fehler „[Vue-Warnung]: Fehlende erforderliche Requisite'.](https://img.php.cn/upload/article/000/887/227/169304743965914.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
So beheben Sie den Fehler „[Vuewarn]:Missingrequiredprop“ Bei der Entwicklung von Vue-Anwendungen tritt manchmal die häufige Fehlermeldung „[Vuewarn]:Missingrequiredprop“ auf. Dieser Fehler bezieht sich normalerweise auf das Fehlen erforderlicher Eigenschaftswerte in der Komponente, was dazu führt, dass die Komponente nicht ordnungsgemäß gerendert wird. Die Lösung dieses Problems ist einfach. Wir können diesen Fehler durch einige Fähigkeiten und Vorschriften vermeiden und beheben. Hier sind einige Lösungen
![So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: ungültiger Wert'.](https://img.php.cn/upload/article/000/465/014/169294628931912.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Methoden zur Behebung des Fehlers „[Vuewarn]:Invalidprop:invalidvalue“ Bei der Entwicklung von Anwendungen mit Vue.js stoßen wir häufig auf einige Fehler und Warnungen. Einer der häufigsten Fehler ist „[Vuewarn]:Invalidprop:invalidvalue“. Dieser Fehler tritt normalerweise auf, wenn wir versuchen, einen ungültigen Wert an eine Eigenschaft einer Vue-Komponente zu übergeben. In diesem Artikel werden wir uns mit der Grundursache dieses Fehlers befassen
![So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: benutzerdefinierter Validator'.](https://img.php.cn/upload/article/000/000/164/169254319231018.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Methoden zur Behebung des Fehlers „[Vuewarn]:Invalidprop:customvalidator“ Während des Entwicklungsprozesses der Verwendung von Vue stoßen wir häufig auf einige Warn- und Fehlermeldungen. Eine der häufigsten Fehlermeldungen ist „[Vuewarn]:Invalidprop:customvalidator“. Der Grund für diese Fehlermeldung liegt darin, dass wir bei Verwendung der benutzerdefinierten Validierungsfunktion die an sie übergebene Komponente nicht korrekt validieren können.
![So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: Typprüfung'.](https://img.php.cn/upload/article/000/887/227/169306085649427.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
So beheben Sie den Fehler „[Vuewarn]:Invalidprop:typecheck“ Vue.js ist ein beliebtes JavaScript-Framework zum Erstellen von Benutzeroberflächen. Bei der Entwicklung von Anwendungen mit Vue.js stoßen wir manchmal auf Fehlermeldungen, darunter „[Vuewarn]:Invalidprop:typecheck“. Dieser Fehler wird normalerweise durch eine falsche Verwendung von Attributen in der Komponente verursacht
![So beheben Sie den Fehler „[Vue-Warnung]: Vermeiden Sie die direkte Mutation einer Requisite'.](https://img.php.cn/upload/article/000/465/014/169226406590115.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Methoden zur Behebung des Fehlers „[Vuewarn]:Avoidmutatingapropdirectly“ Bei der Entwicklung von Projekten mit Vue.js kann es zu einer häufigen Warnmeldung kommen: „[Vuewarn]:Avoidmutatingapropdirectly“. Die Bedeutung dieser Warnmeldung besteht darin, dass wir den Wert eines Props-Attributs nicht direkt ändern sollten, sondern ein Ereignis auslösen sollten, damit die übergeordnete Komponente den Pro ändern kann
![So gehen Sie mit dem Fehler „[Vue-Warnung]: Vermeiden Sie es, eine Requisite direkt zu mutieren' um](https://img.php.cn/upload/article/000/465/014/169224194948720.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Umgang mit dem Fehler „[Vuewarn]:Avoidmutatingapropdirectly“ Bei der Entwicklung von Webanwendungen mit Vue.js stoßen wir häufig auf Warnungen oder Fehler. Eine der häufigsten Warnungen ist „[Vuewarn]:Avoidmutatingapropdirectly“, was bedeutet, dass wir eine von der übergeordneten Komponente übergebene Eigenschaft (prop) direkt in der Komponente ändern. In diesem Artikel haben wir

Vergleich mehrstufiger Bereitstellungsschemata in der Vue-Komponentenkommunikation Vue ist ein sehr beliebtes Front-End-Framework. Es bietet eine komponentenbasierte Entwicklungsmethode und realisiert die Entwicklung komplexer Anwendungen durch die Verschachtelung und Kommunikation von Komponenten. In der tatsächlichen Entwicklung ist die Kommunikation zwischen Komponenten oft ein wichtiges Thema. Wenn mehrstufige Beziehungen zwischen Komponenten bestehen, wird die effiziente Datenübertragung zu einem Problem, über das Entwickler nachdenken müssen. In diesem Artikel werden mehrere gängige mehrstufige Komponentenkommunikationsschemata vorgestellt und verglichen. Verwenden Sie zum Bereitstellen props und $emitVue
![So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: Wert aktualisieren'.](https://img.php.cn/upload/article/000/465/014/169305238381644.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Methoden zur Behebung des Fehlers „[Vuewarn]:Invalidprop:updatevalue“ Bei der Vue-Entwicklung stoßen wir häufig auf den Fehler „[Vuewarn]:Invalidprop:updatevalue“. Dieser Fehler wird normalerweise dadurch verursacht, dass eine übergeordnete Komponente einen ungültigen Wert an eine untergeordnete Komponente übergibt. Obwohl es sich bei diesem Fehler eher um eine Vue-Warnung als um einen schwerwiegenden Fehler handelt, sollte er dennoch rechtzeitig behoben werden, um die Robustheit des Programms sicherzustellen. In diesem Artikel wird vorgestellt
