Heim Web-Frontend js-Tutorial Zusammenfassung der Avalon-Bindungseigenschaften in JavaScript

Zusammenfassung der Avalon-Bindungseigenschaften in JavaScript

Dec 09, 2016 pm 04:10 PM
javascript

Avalon ist ein Front-End-MVVM-Framework, das den gesamten Front-End-Code vollständig in zwei Teile unterteilt. Die Ansichtsverarbeitung wird durch Bindung implementiert (Angular hat einen cooleren Begriff namens Anweisungen), und die Geschäftslogik ist in Objekten namens VMs konzentriert mit. Solange wir mit den Daten der VM arbeiten, werden diese automatisch und auf magische Weise mit der Ansicht synchronisiert.

$model (alle Nicht-$-Attribute), $event (Ereignisobjekt)

1. Bereichsabgrenzung

ms-controller: Bottom-up nach dem Prinzip von Nähe Scannen Sie den DOM-Baum

ms-important: Scannen Sie nur diesen Knoten und darunter als Scanbereich

ms-skip: Machen Sie die Bindung ungültig

2 -way-Bindung Definierte Attribute: Zusätzlich zur Bindung von Daten an den DOM-Knoten (VM synchronisiert Daten mit V), wird auch ein Listening-Ereignis heimlich an den Knoten gebunden. Wenn sich die Knotendaten ändern, werden die Daten in V mit synchronisiert VM rechtzeitig

(1) Text, Passwort, Textbereich erfordern, dass der Bindungswert eine Zeichenfolge ist (ms-duplex-text)

(2)radio: Bindung an booleschen Wert (ms -duplex-boolean)

(3)Kontrollkästchen: Als Array binden (ms-duplex-string)

(4)Auswählen: Als String oder Array binden (ms-duplex-string)

Gefolgt von ms-duplex2.0-Bindungsattributen

3. ms-visible: Ähnlich wie beim Umschalten wird der Ausdruck als wahr angezeigt und durch Einstellen der Anzeige auf „Blockieren“ oder „Keine“ angezeigt oder ausgeblendet.

4. Einfügungs- und Entfernungsverarbeitung ms-if: Knotenelement-Anzeigeelement hinzufügen, <!--ms-if--> Kommentar für versteckten Knoten festlegen (Knoten löschen)

5. Daten ms-data- * zwischenspeichern, ms-data verwenden, um das Objekt oder Array zu speichern (an das DOM-Knotenobjekt binden statt als Attribut), es auf dem Knoten speichern, die Rückgabe beim Anzeigen verarbeiten und als data-* binden Attribut

6. Attribut Operate ms-class(class),ms-duplex(value),ms-attr,ms-href,ms-src

boolesche Attribute: ms-attr-disabled ,ms-attr-readonly,ms-attr -selected,ms-attr-checked

String inhärente Attribute: ms-attr-id,ms-attr-name,ms-attr-title,ms-src, ms-href

Benutzerdefinierte Attribute: ms-attr-data-url, ms-attr-data-id

ms-class: ms-class='active' ms-class ='active:isOk'
ms-active,ms-hover

7, ms-duplex2.0

ms-duplex-string,ms-duplex-number,ms-duplex-checked,ms-duplex-boolean,ms-data-duplex
Nach dem Login kopieren

Hilfsdaten-Duplex-Fokus, Daten-Duplex-Geändert, Daten-Duplex-Ereignis

8. Stiloperationen: ms-css (inline), ms-class (externe Einführung)

&lt;button ms-click=&quot;toggle&quot; ms-css-width=&quot;100&quot;&gt;显示&lt;/button&gt; &lt;span ms-if=&quot;flag&quot;&gt;{{message}}&lt;/span&gt;
Nach dem Login kopieren

9. Ereignisbindung: ms-on-eventName,ms-eventName

ms-mouseenter, ms-mouseleave (gilt nur für ausgewählte Elemente), ms -input(ms- on-input), die Bindungsreihenfolge mehrerer Ereignisse hat nichts mit natürlichen Zahlen zu tun, sondern hängt mit der Reihenfolge der Ereignisse zusammen

10 Schleifenoperation

ms-each-traverse temporäre Variablen (auf der Bindung des übergeordneten Elements)

ms-repeat – Temporäre Variablen durchlaufen (an untergeordnete Elemente binden)

ms-with – Temporäre Variablen durchlaufen (an untergeordnete Elemente binden). übergeordnete Elemente)

Array: el temporäre Standardvariable, $index der Index des aktuellen Elements, ob $first das erste Element ist boolean, $last, $remove gibt eine Funktion zum Löschen des aktuellen Elements $outer zurück Variable der inneren Schleife der äußeren Schleife

Hash (Objekt): $key Schlüsselname, $val Schlüsselwert, $outer ($outer.$index)

&lt;ul&gt; &lt;li ms-repeat-e=&quot;data&quot;&gt;{{e}}&lt;/li&gt; &lt;/ul&gt; &lt;ul ms-each-e=&quot;data&quot;&gt; &lt;li&gt;{{e}}&lt;/li&gt; &lt;/ul&gt;
Nach dem Login kopieren

Ändern Sie den Schlüsselwert des Objekts:

Ändern Sie das Schlüsselwertpaar des Objekts:

Ändern Sie den Wert des Arrays: array object.set(subscript, value )

Ändern Sie den Wert des Objekts im Array :Array-Objekt [Subscript]

Traversal-Callback-Funktion (Eigenschaft)

data-each -rendered

data-with-rendered

data-repeat-rendered

data-with-sorted

Verwenden Sie die Größe, um die Datenlänge beim Schleifen zu berechnen , nicht Länge, verwenden Sie ms-if-loop anstelle von ms-if, da ms-if Vorrang vor ms-repeat hat

11 Vorlagenreferenz

12 🎜>13. Modulkommunikation

Im Folgenden wird die Abgrenzungsmethode von Avalon vorgestellt

Bei der Verwendung von AvalonJS für die Front-End-Entwicklung müssen Sie den Datenbindungsbereich abgrenzen. Es gibt drei Methoden:

(1) ms-controller: Dieses Bindungsattribut wird verwendet. Begrenzen Sie den Bereich basierend auf dem Prinzip der Nähe. Beginnen Sie zunächst mit diesem Tag und suchen Sie online

(2) ms-important: Dieses Bindungsattribut Sucht nur nach diesem Tag. Wenn die VM-Bindungsdaten nicht gefunden werden, werden sie unverändert auf der Seite ausgegeben.

(3) ms-skip: Die Funktion dieses Bindungsattributs besteht darin, Daten ungültig zu machen Bindung, das heißt, der Interpolationsausdruck wird unverändert ausgegeben, unabhängig davon, ob die gebundenen Daten im Bereich gefunden werden oder nicht

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 Artikel -Tags

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 implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript Dec 17, 2023 pm 02:54 PM

So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen Dec 17, 2023 pm 05:30 PM

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript Dec 17, 2023 am 09:39 AM

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript

Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Dec 17, 2023 pm 12:09 PM

Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems

Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Jan 05, 2024 pm 06:08 PM

Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Dec 17, 2023 pm 05:13 PM

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems

So verwenden Sie insertBefore in Javascript So verwenden Sie insertBefore in Javascript Nov 24, 2023 am 11:56 AM

So verwenden Sie insertBefore in Javascript

So erhalten Sie auf einfache Weise HTTP-Statuscode in JavaScript So erhalten Sie auf einfache Weise HTTP-Statuscode in JavaScript Jan 05, 2024 pm 01:37 PM

So erhalten Sie auf einfache Weise HTTP-Statuscode in JavaScript

See all articles