


So verwenden Sie die Anweisungen von Vue.js, um die Funktion „Alle auswählen' zu implementieren
In diesem Artikel wird hauptsächlich die Verwendung des Vue.js-Befehls zum Implementieren der Select-All-Funktion vorgestellt. Er hat einen bestimmten Referenzwert. Jetzt können Freunde in Not darauf verweisen Ich habe kürzlich zwei Vue-Projekte erstellt, die alle die Funktion „Alle auswählen“ und „Umkehren der Auswahl“ implementieren müssen. Das erste Projekt verwendet die berechneten Methoden von Vue, und das zweite Projekt verwendet Anweisungen, um es zu implementieren Die Anweisungen sind bequemer. Als Nächstes stellen wir vor, wie Sie mithilfe von Anweisungen alles auswählen können.
Da ich erst vor kurzem angefangen habe, Vue zu kontaktieren, bezieht sich die Implementierung der vollständigen Auswahl auf die Implementierungsmethode auf Zhihu:
1. Holen Sie sich die Daten vom Server und legen Sie fest geprüftes Attribut für jedes Element
2. Berechnen Sie die ausgewählte Anzahl selectCount. Wenn die ausgewählte Anzahl gleich der Anzahl der selectItems ist, wählen Sie alle selectAll selected aus
3. Wann Sie klicken auf „Alle auswählen“, jedes. Das überprüfte Attribut jedes Elements wird auf „true“ gesetzt und bei Umkehrung auf „false“ gesetzt.
4. Jedes Mal, wenn sich das Attribut von „selectItems“ ändert, erhält das überprüfte Element den Wert „true“. wird in das Array „checkedGroups“ eingefügt
//全选 data: function() { return { selectItems: [], // 从服务器拿到的数据 } }, computed: { // 全选checkbox绑定的model selectAll: { get: function() { return this.selectCount == this.selectItems.length; }, set: function(value) { this.selectItems.forEach(function(item) { item.checked = value; }); return value; } }, //选中的数量 selectCount: { get: function() { var i = 0; this.selectItems.forEach(function(item) { if (item.checked) { i++; } }); return i; } }, //选中的数组 checkedGroups: { get: function() { var checkedGroups = []; this.selectItems.forEach(function(item) { if (item.checked) { checkedGroups.push(item); } }); return checkedGroups; } } }
Diese Methode ist nicht praktisch Erstens ist es schwierig, es jedes Mal wiederzuverwenden, wenn Sie es verwenden möchten. Zweitens sind „selectAll“, „checkedGroups“ und „selectItems“ alle fest und nicht sehr flexibel.
In diesem Projekt habe ich Vue-Anweisungen verwendet, um die Funktion zum Auswählen aller Elemente erneut zu implementieren. Die Idee der Direktive ähnelt tatsächlich der des berechneten Codes:
export default { 'check-all': { twoWay: true, params: ['checkData'], bind() { /** - 如果所有的列表的checked属性都为true,则选中全选框,否则不选中全选框 */ this.vm.$watch(this.params.checkData, (checkData) => { if (checkData.every((item) => item.checked)) { this.set(true); } else { this.set(false); } }, { deep: true }); }, // checkAll发生更改时 update(checkAll) { /** - 如果全选框被选中,则将列表的所有checked属性转为true,否则转为false */ if (checkAll) { this.vm[this.params.checkData].forEach((item) => { item.checked = true; }); } else { this.vm[this.params.checkData].forEach((item) => { item.checked = false; }); } }, }, };Anruf:
<input type="checkbox" v-model="checkAll" v-check-all="checkAll" check-data="checkData"> <ul> <li v-for="item in checkData"> <input type="checkbox" v-model="item.checked"> {{item.text}} </li> </ul>Lass uns zunächst über die Vorteile der Verwendung sprechen es so:
1 Einfach zu verwenden, schreiben Sie einfach den
wo nötig v-check-all
check-data
2 Der Name des Arrays kann angepasst werden. Sie können einen beliebigen Namen verwenden. Wenn Sie das ausgewählte Modell nicht checkAll nennen möchten, können Sie es checkAllData nennen. Wenn Sie nicht möchten, dass das Array checkData heißt, können Sie es dataFromServer nennen .
Geben Sie im Befehl twoWay als true an. Sie können
verwenden, um den Wert von checkAll festzulegen, und params verwenden, um den Attributwert checkData für das Bindungsbefehlselement zu empfangen, bei dem es sich um das Array handelt, das benötigt wird operiert werden.this.set(value)
Verwenden Sie
auf, um Änderungen in checkData zu überwachen. Wenn alle checkData ausgewählt sind, setzen Sie checkAll auf true, andernfalls setzen Sie checkAll auf false. this.vm
$watch
Wenn sich der Anweisungswert (checkAll) ändert und er wahr ist, setzen Sie die überprüften Attribute von checkData auf wahr, andernfalls ist er falsch. An diesem Punkt ist ein „Alle auswählen“-Befehl abgeschlossen.
Als ich diesen Befehl „Alle auswählen“ ausführte, wollte ich ursprünglich paramWatchers verwenden, um Änderungen in checkData zu überwachen, aber ich habe festgestellt, dass der Rückruf von paramWatchers nicht ausgelöst wird, nachdem ich mir den Quellcode angesehen habe Ich habe festgestellt, dass paramWatchers tatsächlich auch
aufgerufen wird, die Tiefenerkennung jedoch nicht unterstützt wird:$watch
Directive.prototype._setupParamWatcher = function (key, expression) { var self = this; var called = false; var unwatch = (this._scope || this.vm).$watch(expression, function (val, oldVal) { self.params[key] = val; // since we are in immediate mode, // only call the param change callbacks if this is not the first update. if (called) { var cb = self.paramWatchers && self.paramWatchers[key]; if (cb) { cb.call(self, val, oldVal); } } else { called = true; } }, { immediate: true, user: false });(this._paramUnwatchFns || (this._paramUnwatchFns = [])).push(unwatch); };
Das Obige ist der gesamte Inhalt dieses Artikels, ich hoffe es wird für das Lernen aller hilfreich sein. Weitere Informationen finden Sie auf der chinesischen PHP-Website.
Verwandte Empfehlungen:
Analyse zur Verwendung von Vue-RoutingAnalyse dazu, wie Vue globale Sass-Variablen einführtVerwenden Sie den Vue-Router, um einfache Navigationsfunktionen auszuführenDas obige ist der detaillierte Inhalt vonSo verwenden Sie die Anweisungen von Vue.js, um die Funktion „Alle auswählen' zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Kraft des JavaScript -Frameworks liegt in der Vereinfachung der Entwicklung, der Verbesserung der Benutzererfahrung und der Anwendungsleistung. Betrachten Sie bei der Auswahl eines Frameworks: 1. Projektgröße und Komplexität, 2. Teamerfahrung, 3. Ökosystem und Community -Unterstützung.

Einführung Ich weiß, dass Sie es vielleicht seltsam finden. Was genau muss JavaScript, C und Browser tun? Sie scheinen nicht miteinander verbunden zu sein, aber tatsächlich spielen sie eine sehr wichtige Rolle in der modernen Webentwicklung. Heute werden wir die enge Verbindung zwischen diesen drei diskutieren. In diesem Artikel erfahren Sie, wie JavaScript im Browser ausgeführt wird, die Rolle von C in der Browser -Engine und wie sie zusammenarbeiten, um das Rendern und die Interaktion von Webseiten voranzutreiben. Wir alle kennen die Beziehung zwischen JavaScript und Browser. JavaScript ist die Kernsprache der Front-End-Entwicklung. Es läuft direkt im Browser und macht Webseiten lebhaft und interessant. Haben Sie sich jemals gefragt, warum Javascr

Node.js zeichnet sich bei effizienten E/A aus, vor allem bei Streams. Streams verarbeiten Daten inkrementell und vermeiden Speicherüberladung-ideal für große Dateien, Netzwerkaufgaben und Echtzeitanwendungen. Die Kombination von Streams mit der TypeScript -Sicherheit erzeugt eine POWE

Die Unterschiede in der Leistung und der Effizienz zwischen Python und JavaScript spiegeln sich hauptsächlich in: 1 wider: 1) Als interpretierter Sprache läuft Python langsam, weist jedoch eine hohe Entwicklungseffizienz auf und ist für eine schnelle Prototypentwicklung geeignet. 2) JavaScript ist auf einen einzelnen Thread im Browser beschränkt, aber Multi-Threading- und Asynchronen-E/A können verwendet werden, um die Leistung in Node.js zu verbessern, und beide haben Vorteile in tatsächlichen Projekten.

JavaScript stammt aus dem Jahr 1995 und wurde von Brandon Ike erstellt und realisierte die Sprache in C. 1.C-Sprache bietet Programmierfunktionen auf hoher Leistung und Systemebene für JavaScript. 2. Die Speicherverwaltung und die Leistungsoptimierung von JavaScript basieren auf C -Sprache. 3. Die plattformübergreifende Funktion der C-Sprache hilft JavaScript, auf verschiedenen Betriebssystemen effizient zu laufen.

JavaScript wird in Browsern und Node.js -Umgebungen ausgeführt und stützt sich auf die JavaScript -Engine, um Code zu analysieren und auszuführen. 1) abstrakter Syntaxbaum (AST) in der Parsenstufe erzeugen; 2) AST in die Kompilierungsphase in Bytecode oder Maschinencode umwandeln; 3) Führen Sie den kompilierten Code in der Ausführungsstufe aus.

Zu den zukünftigen Trends von Python und JavaScript gehören: 1. Python wird seine Position in den Bereichen wissenschaftlicher Computer und KI konsolidieren. JavaScript wird die Entwicklung der Web-Technologie fördern. Beide werden die Anwendungsszenarien in ihren jeweiligen Bereichen weiter erweitern und mehr Durchbrüche in der Leistung erzielen.

Sowohl Python als auch JavaScripts Entscheidungen in Entwicklungsumgebungen sind wichtig. 1) Die Entwicklungsumgebung von Python umfasst Pycharm, Jupyternotebook und Anaconda, die für Datenwissenschaft und schnelles Prototyping geeignet sind. 2) Die Entwicklungsumgebung von JavaScript umfasst Node.JS, VSCODE und WebPack, die für die Entwicklung von Front-End- und Back-End-Entwicklung geeignet sind. Durch die Auswahl der richtigen Tools nach den Projektbedürfnissen kann die Entwicklung der Entwicklung und die Erfolgsquote der Projekte verbessert werden.


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

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Dreamweaver CS6
Visuelle Webentwicklungstools

Dreamweaver Mac
Visuelle Webentwicklungstools

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version
