Heim Web-Frontend js-Tutorial Der Unterschied zwischen attr- und prop-Attributen in JS und eine Einführung in Beispiele für die Prioritätsauswahl_Grundkenntnisse

Der Unterschied zwischen attr- und prop-Attributen in JS und eine Einführung in Beispiele für die Prioritätsauswahl_Grundkenntnisse

May 16, 2016 pm 04:42 PM
prop

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; 
} 
}
Nach dem Login kopieren

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 ]; 
} 
} 
}
Nach dem Login kopieren

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" />
Nach dem Login kopieren

$(function(){ 
el = $("#test"); 
console.log(el.attr("style")); //undefined 
console.log(el.prop("style")); //CSSStyleDeclaration对象 
console.log(document.getElementById("test").style); //CSSStyleDeclaration对象 
});
Nach dem Login kopieren

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
Nach dem Login kopieren


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

abgerufen werden kann

el.prop("abc", "222"); 
console.log(el.attr("abc")); //111 
console.log(el.prop("abc")); //222
Nach dem Login kopieren

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" />
Nach dem Login kopieren
console.log(el.attr("checked")); //checked 
console.log(el.prop("checked")); //true 
console.log(el.attr("disabled")); //undefined 
console.log(el.prop("disabled")); //false
Nach dem Login kopieren


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():

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So beheben Sie den Fehler „[Vue-Warnung]: Fehlende erforderliche Requisite'. So beheben Sie den Fehler „[Vue-Warnung]: Fehlende erforderliche Requisite'. Aug 26, 2023 pm 06:57 PM

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'. So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: ungültiger Wert'. Aug 25, 2023 pm 02:51 PM

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'. So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: benutzerdefinierter Validator'. Aug 20, 2023 pm 10:53 PM

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'. So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: Typprüfung'. Aug 26, 2023 pm 10:40 PM

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'. So beheben Sie den Fehler „[Vue-Warnung]: Vermeiden Sie die direkte Mutation einer Requisite'. Aug 17, 2023 pm 05:21 PM

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 So gehen Sie mit dem Fehler „[Vue-Warnung]: Vermeiden Sie es, eine Requisite direkt zu mutieren' um Aug 17, 2023 am 11:12 AM

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 Vergleich mehrstufiger Bereitstellungsschemata in der Vue-Komponentenkommunikation Jul 18, 2023 pm 03:21 PM

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'. So beheben Sie den Fehler „[Vue-Warnung]: Ungültige Requisite: Wert aktualisieren'. Aug 26, 2023 pm 08:19 PM

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

See all articles