Analyse von vier Fragen zur Funktion .grep() von jQuery
Frage 1: Was ist der Quellcode von jQuery.grep?
//grep函数,第三个参数表示是否根据fn的结果取反! grep: function( elems, callback, invert ) { var callbackInverse, matches = [], i = 0, //保存数组个数 length = elems.length, //对传入的第二个参数取反,true变成false,false变成true //如果invert为false,即!inverse为true,那么直接把函数返回true的元素加入,所以期望callbackExpect的就是true callbackExpect = !invert; // Go through the array, only saving the items // that pass the validator function for ( ; i < length; i++ ) { //如果invert是false,表示不取反,那么如果fn返回true,就直接加入进去matches数组 //获取回调函数结果的返回值的取反的结果 callbackInverse = !callback( elems[ i ], i ); if ( callbackInverse !== callbackExpect ) { matches.push( elems[ i ] ); } } return matches; }
Frage 2: Was sind die aufrufenden Methoden von jQuery.grep?
In der Winnow-Funktion
if ( qualifier.nodeType ) { return jQuery.grep( elements, function( elem ) {//没有第三个参数,表示获取执行函数后返回为true元素在结果数组中 return ( elem === qualifier ) !== not; }); }
In der Winnow-Funktion gibt es auch einen Aufruf
return jQuery.grep( elements, function( elem ) { return ( jQuery.inArray( elem, qualifier ) >= 0 ) !== not;<span style="font-family: Arial, Helvetica, sans-serif;">//没有第三个参数,表示获取执行函数后返回为true元素在结果数组中</span> });
oder in der Winnow-Methode
return jQuery.grep( elements, function( elem, i ) { /* jshint -W018 */ return !!qualifier.call( elem, i, elem ) !== not;<span style="font-family: Arial, Helvetica, sans-serif;">//没有第三个参数,表示获取执行函数后返回为true元素在结果数组中</span> });
und in jQuery.buildFragment,
jQuery.grep( getAll( nodes, "input" ), fixDefaultChecked );
wird aufgerufen. Diese Methode verwendet das Attribut „defaultChecked“ aller Eingabeelemente auf dasselbe wie „checked“. Frage 3: Welche Funktion hat die Methode jQuery.grep?
// Used in buildFragment, fixes the defaultChecked property var rcheckableType = (/^(?:checkbox|radio)$/i); function fixDefaultChecked( elem ) { if ( rcheckableType.test( elem.type ) ) { elem.defaultChecked = elem.checked;//这里没有明确返回真或者假,所以他只是用来修改元素,而不再保存修改后的数组! } }
Diese Funktion Der Rückgabewert ist ein Array!
Wir analysieren anhand des folgenden Beispiels, wie das Element ausgewählt wird, dessen ID und Klasse beide Vater sind
JS-Teil
<p class="father" id="father" style="background-color:red;height:400px;background-color:#ccc;"> </p> <p class="father" style="background-color:red;height:400px;background-color:#ccc;"> </p>
Grep bestimmt also die zurückgegebenen Elemente danach, ob der Rückgabewert wahr oder falsch ist. Alle Elemente, die die Bedingungen erfüllen, bilden eine DOM-Sammlung! Bleibt unverändert, wir ändern den JS-Teil wie folgt:
//对每一个元素进行筛选,只有符合条件的元素才会在结果数组中! var result=jQuery.grep($(".father"),function(elem,index) { return elem.id==="father"; //grep通过false,true来判断是否在结果集合中;map通过明确的return elem //而each通过false,true决定是否退出循环 }); console.log(result);//打印[p#father.father]
Dies Da der dritte Parameter wahr ist, wird er intern invertiert, was bedeutet, dass wir möchten, dass das Element mit dem Wert false im Ergebnis erscheint Array, sodass das Ergebnisarray nur das zweite p-Element enthält.
//对每一个元素进行筛选,只有符合条件的元素才会在结果数组中! var result=jQuery.grep($(".father"),function(elem,index) { return elem.id==="father"; //grep通过false,true来判断是否在结果集合中;map通过明确的return elem //而each通过false,true决定是否退出循环 },true); console.log(result);//[p.father]
(Nur jQuery.each und jede Instanz, der erste Parameter der Kartenmethode ist der Index und der zweite Parameter ist das Element!)
//下面的代码可以修改为: callbackResult = callback( elems[ i ], i );//调用函数的结果 if ( callbackResult === callbackExpect ) {//如果调用的结果和期望的结果一样,那么直接放进结果数组返回 matches.push( elems[ i ] ); }
Zusammenfassung:
(1) Die $.each-Methode betont das Durchlaufen aller Elemente und das anschließende Ausführen einer Rückruffunktion Filtern Sie alle Elemente nach einer Funktion und lassen Sie alle Elemente eine Funktion ausführen, um zu sehen, ob der Rückgabewert dem erwarteten Rückgabewert entspricht. Wenn er den erwarteten Rückgabewert erfüllt, kann er in das Ergebnisarray aufgenommen werden negieren, also betont grep das Filtern, d. Jede Rückruffunktion wird übergeben. Die übergebenen Parameter sind der Index und das Element, wobei der Index vorne und das Element hinten steht. Die von anderen grep- oder Map-Methoden übergebenen Parameter sind das Element und der Index, wobei das Element vorne steht und der Index hinten (außer zum Beispiel „map“ und „jede“-Methode)!
Das obige ist der detaillierte Inhalt vonAnalyse von vier Fragen zur Funktion .grep() von jQuery. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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

Detaillierte Erläuterung der jQuery-Referenzmethode: Kurzanleitung jQuery ist eine beliebte JavaScript-Bibliothek, die häufig in der Website-Entwicklung verwendet wird. Sie vereinfacht die JavaScript-Programmierung und bietet Entwicklern umfangreiche Funktionen und Features. In diesem Artikel wird die Referenzmethode von jQuery ausführlich vorgestellt und spezifische Codebeispiele bereitgestellt, um den Lesern einen schnellen Einstieg zu erleichtern. Einführung in jQuery Zuerst müssen wir die jQuery-Bibliothek in die HTML-Datei einführen. Es kann über einen CDN-Link eingeführt oder heruntergeladen werden

Wie verwende ich die PUT-Anfragemethode in jQuery? In jQuery ähnelt die Methode zum Senden einer PUT-Anfrage dem Senden anderer Arten von Anfragen, Sie müssen jedoch auf einige Details und Parametereinstellungen achten. PUT-Anfragen werden normalerweise zum Aktualisieren von Ressourcen verwendet, beispielsweise zum Aktualisieren von Daten in einer Datenbank oder zum Aktualisieren von Dateien auf dem Server. Das Folgende ist ein spezifisches Codebeispiel, das die PUT-Anforderungsmethode in jQuery verwendet. Stellen Sie zunächst sicher, dass Sie die jQuery-Bibliotheksdatei einschließen. Anschließend können Sie eine PUT-Anfrage senden über: $.ajax({u

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Bei der Front-End-Entwicklung müssen wir häufig die Höhenattribute von Elementen manipulieren. Manchmal müssen wir möglicherweise die Höhe eines Elements dynamisch ändern, und manchmal müssen wir das Höhenattribut eines Elements entfernen. In diesem Artikel wird erläutert, wie Sie mit jQuery das Höhenattribut eines Elements entfernen, und es werden spezifische Codebeispiele bereitgestellt. Bevor wir jQuery zum Betreiben des Höhenattributs verwenden, müssen wir zunächst das Höhenattribut in CSS verstehen. Das Höhenattribut wird verwendet, um die Höhe eines Elements festzulegen

Titel: jQuery-Tipps: Ändern Sie schnell den Text aller Tags auf der Seite. In der Webentwicklung müssen wir häufig Elemente auf der Seite ändern und bedienen. Wenn Sie jQuery verwenden, müssen Sie manchmal den Textinhalt aller a-Tags auf der Seite gleichzeitig ändern, was Zeit und Energie sparen kann. Im Folgenden wird erläutert, wie Sie mit jQuery den Text aller Tags auf der Seite schnell ändern können, und es werden spezifische Codebeispiele angegeben. Zuerst müssen wir die jQuery-Bibliotheksdatei einführen und sicherstellen, dass der folgende Code in die Seite eingefügt wird: <

Titel: Verwenden Sie jQuery, um den Textinhalt aller Tags zu ändern. jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur Verarbeitung von DOM-Operationen verwendet wird. Bei der Webentwicklung müssen wir häufig den Textinhalt des Link-Tags (eines Tags) auf der Seite ändern. In diesem Artikel wird erläutert, wie Sie mit jQuery dieses Ziel erreichen, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir die jQuery-Bibliothek in die Seite einführen. Fügen Sie den folgenden Code in die HTML-Datei ein:

jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur DOM-Manipulation und Ereignisbehandlung in Webseiten verwendet wird. In jQuery wird die Methode eq() verwendet, um Elemente an einer bestimmten Indexposition auszuwählen. Die spezifischen Verwendungs- und Anwendungsszenarien sind wie folgt. In jQuery wählt die Methode eq() das Element an einer angegebenen Indexposition aus. Indexpositionen beginnen bei 0 zu zählen, d. h. der Index des ersten Elements ist 0, der Index des zweiten Elements ist 1 und so weiter. Die Syntax der eq()-Methode lautet wie folgt: $("s

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wenn Sie jQuery zum Betreiben von DOM-Elementen verwenden, stoßen Sie häufig auf Situationen, in denen Sie feststellen müssen, ob ein Element ein bestimmtes Attribut hat. In diesem Fall können wir diese Funktion einfach mit Hilfe der von jQuery bereitgestellten Methoden implementieren. Im Folgenden werden zwei häufig verwendete Methoden vorgestellt, um festzustellen, ob ein jQuery-Element über bestimmte Attribute verfügt, und um spezifische Codebeispiele anzuhängen. Methode 1: Verwenden Sie die Methode attr() und den Operator typeof //, um zu bestimmen, ob das Element ein bestimmtes Attribut hat

jQuery ist eine beliebte JavaScript-Bibliothek, die häufig in der Webentwicklung verwendet wird. Während der Webentwicklung ist es häufig erforderlich, mithilfe von JavaScript dynamisch neue Zeilen zu Tabellen hinzuzufügen. In diesem Artikel wird erläutert, wie Sie mit jQuery neue Zeilen zu einer Tabelle hinzufügen, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir die jQuery-Bibliothek in die HTML-Seite einführen. Die jQuery-Bibliothek kann über den folgenden Code in das Tag eingeführt werden:
