


Wie kommuniziere ich zwischen Vue-Komponenten? Kurze Analyse von sechs Methoden
Mar 22, 2023 pm 04:54 PMWie kommuniziere ich zwischen Vue-Komponenten? Der folgende Artikel stellt Ihnen die sechs M?glichkeiten der Vue-Komponentenkommunikation vor. Ich hoffe, er ist hilfreich für Sie!
Komponenten sind eine der leistungsst?rksten Funktionen von vue.js, und die Bereiche der Komponenteninstanzen sind unabh?ngig voneinander, was bedeutet, dass Daten zwischen verschiedenen Komponenten nicht aufeinander verweisen k?nnen. Im Allgemeinen k?nnen Komponenten mehrere Beziehungen haben.
Wie w?hlt man eine effektive Kommunikationsmethode für verschiedene Nutzungsszenarien aus? Dies ist das Thema, das wir untersuchen werden. Dieser Artikel fasst verschiedene Arten der Kommunikation zwischen Vue-Komponenten zusammen, wie z. B. props, emit/emit/on, vuex, parent/parent/children, attrs/attrs/listeners und Provide/inject, und erl?utert die Unterschiede anhand leicht verst?ndlicher Beispiele . und Nutzungsszenarien, ich hoffe, es kann meinen Freunden helfen. [Verwandte Empfehlungen: vuejs-Video-Tutorial, Web-Front-End-Entwicklung]
Methode 1, Requisiten/$emit
übergeordnete Komponente A wird über Requisiten an untergeordnete Komponente B übergeben, und B an A übergibt $emit in B-Komponente , implementiert von v-on in Komponente A.
1. Die übergeordnete Komponente übergibt den Wert an die untergeordnete Komponente.
Als N?chstes veranschaulichen wir anhand eines Beispiels, wie die übergeordnete Komponente den Wert an die untergeordnete Komponente weitergibt: So erhalten Sie die Datenbenutzer in der übergeordneten Komponente App.vue im untergeordneten Element Komponente Users.vue:["Henry","Bucky", "Emily"]
//App.vue父組件 <template> <div id="app"> <users v-bind:users="users"></users>//前者自定義名稱便于子組件調(diào)用,后者要傳遞數(shù)據(jù)名 </div> </template> <script> import Users from "./components/Users" export default { name: 'App', data(){ return{ users:["Henry","Bucky","Emily"] } }, components:{ "users":Users } }
//users子組件 <template> <div class="hello"> <ul> <li v-for="user in users">{{user}}</li>//遍歷傳遞過來的值,然后呈現(xiàn)到頁面 </ul> </div> </template> <script> export default { name: 'HelloWorld', props:{ users:{ //這個(gè)就是父組件中子標(biāo)簽自定義名字 type:Array, required:true } } } </script>
Zusammenfassung: Die übergeordnete Komponente gibt Daten über Requisiten an die untergeordnete Komponente weiter. Hinweis: Es gibt drei Formen von Daten in Komponenten: Daten, Requisiten, berechnet ?an übergeordnete Komponenten. Komponente übergibt Wert: Wenn wir auf ?Vue.js Demo“ klicken, übergibt die untergeordnete Komponente den Wert an die übergeordnete Komponente und der Text ?ndert sich von ursprünglich ?Ein Wert wird übergeben“ zu ?Das untergeordnete Element übergibt den Wert“. zur übergeordneten Komponente", Realisierung der untergeordneten Komponente zur übergeordneten Komponente. übergabe von Komponentenwerten.
// 子組件 <template> <header> <h1 @click="changeTitle">{{title}}</h1>//綁定一個(gè)點(diǎn)擊事件 </header> </template> <script> export default { name: 'app-header', data() { return { title:"Vue.js Demo" } }, methods:{ changeTitle() { this.$emit("titleChanged","子向父組件傳值");//自定義事件 傳遞值“子向父組件傳值” } } } </script>
// 父組件 <template> <div id="app"> <app-header v-on:titleChanged="updateTitle" ></app-header>//與子組件titleChanged自定義事件保持一致 // updateTitle($event)接受傳遞過來的文字 <h2>{{title}}</h2> </div> </template> <script> import Header from "./components/Header" export default { name: 'App', data(){ return{ title:"傳遞的是一個(gè)值" } }, methods:{ updateTitle(e){ //聲明這個(gè)函數(shù) this.title = e; } }, components:{ "app-header":Header, } } </script>
Zusammenfassung: Die untergeordnete Komponente sendet über Ereignisse Nachrichten an die übergeordnete Komponente. Tats?chlich sendet die untergeordnete Komponente ihre eigenen Daten an die übergeordnete Komponente.
Methode 2, $emit
/$on
Diese Methode verwendet eine leere Vue-Instanz als zentralen Ereignisbus (Event Center). Es l?st Ereignisse aus und überwacht Ereignisse. Es implementiert auf clevere und einfache Weise die Kommunikation zwischen allen Komponenten, einschlie?lich Vater-Sohn, Bruder und zwischen Ebenen. Wenn unser Projekt relativ gro? ist, k?nnen wir vuex w?hlen, eine bessere L?sung für das Zustandsmanagement.
1. Spezifische Implementierungsmethode: var Event=new Vue();
Event.$emit(事件名,數(shù)據(jù));
Event.$on(事件名,data => {});
$emit
/$on
這種方法通過一個(gè)空的Vue實(shí)例作為中央事件總線(事件中心),用它來觸發(fā)事件和監(jiān)聽事件,巧妙而輕量地實(shí)現(xiàn)了任何組件間的通信,包括父子、兄弟、跨級。當(dāng)我們的項(xiàng)目比較大時(shí),可以選擇更好的狀態(tài)管理解決方案vuex。
1.具體實(shí)現(xiàn)方式:
<div id="itany"> <my-a></my-a> <my-b></my-b> <my-c></my-c> </div> <template id="a"> <div> <h3>A組件:{{name}}</h3> <button @click="send">將數(shù)據(jù)發(fā)送給C組件</button> </div> </template> <template id="b"> <div> <h3>B組件:{{age}}</h3> <button @click="send">將數(shù)組發(fā)送給C組件</button> </div> </template> <template id="c"> <div> <h3>C組件:{{name}},{{age}}</h3> </div> </template> <script> var Event = new Vue();//定義一個(gè)空的Vue實(shí)例 var A = { template: '#a', data() { return { name: 'tom' } }, methods: { send() { Event.$emit('data-a', this.name); } } } var B = { template: '#b', data() { return { age: 20 } }, methods: { send() { Event.$emit('data-b', this.age); } } } var C = { template: '#c', data() { return { name: '', age: "" } }, mounted() {//在模板編譯完成后執(zhí)行 Event.$on('data-a',name => { this.name = name;//箭頭函數(shù)內(nèi)部不會產(chǎn)生新的this,這邊如果不用=>,this指代Event }) Event.$on('data-b',age => { this.age = age; }) } } var vm = new Vue({ el: '#itany', components: { 'my-a': A, 'my-b': B, 'my-c': C } }); </script>
2.舉個(gè)例子
假設(shè)兄弟組件有三個(gè),分別是A、B、C組件,C組件如何獲取A或者B組件的數(shù)據(jù)
let defaultCity = "上海" try { // 用戶關(guān)閉了本地存儲功能,此時(shí)在外層加個(gè)try...catch if (!defaultCity){ defaultCity = JSON.parse(window.localStorage.getItem('defaultCity')) } }catch(e){} export default new Vuex.Store({ state: { city: defaultCity }, mutations: { changeCity(state, city) { state.city = city try { window.localStorage.setItem('defaultCity', JSON.stringify(state.city)); // 數(shù)據(jù)改變的時(shí)候把數(shù)據(jù)拷貝一份保存到localStorage里面 } catch (e) {} } } })
$on
2. Angenommen, es gibt drei Geschwisterkomponenten, n?mlich A-, B- und C-Komponenten
JSON.stringify(state.subscribeList); // array -> string JSON.parse(window.localStorage.getItem("subscribeList")); // string -> array 復(fù)制代碼
$ on
lauscht auf die benutzerdefinierten Ereignisse data-a und data-b. Da manchmal nicht sicher ist, wann das Ereignis ausgel?st wird, wird es normalerweise im gemounteten oder erstellten Hook überwacht.
Methode 3, vuex2.簡要介紹各模塊在流程中的功能: Vue Components:Vue組件。HTML頁面上,負(fù)責(zé)接收用戶操作等交互行為,執(zhí)行dispatch方法觸發(fā)對應(yīng)action進(jìn)行回應(yīng)。 dispatch:操作行為觸發(fā)方法,是唯一能執(zhí)行action的方法。 actions:操作行為處理模塊,由組件中的$store.dispatch('action 名稱', data1)來觸發(fā)。然后由commit()來觸發(fā)mutation的調(diào)用 , 間接更新 state。負(fù)責(zé)處理Vue Components接收到的所有交互行為。包含同步/異步操作,支持多個(gè)同名方法,按照注冊的順序依次觸發(fā)。向后臺API請求的操作就在這個(gè)模塊中進(jìn)行,包括觸發(fā)其他action以及提交mutation的操作。該模塊提供了Promise的封裝,以支持action的鏈?zhǔn)接|發(fā)。 commit:狀態(tài)改變提交操作方法。對mutation進(jìn)行提交,是唯一能執(zhí)行mutation的方法。 mutations:狀態(tài)改變操作方法,由actions中的commit('mutation 名稱')來觸發(fā)。是Vuex修改state的唯一推薦方法。該方法只能進(jìn)行同步操作,且方法名只能全局唯一。操作之中會有一些hook暴露出來,以進(jìn)行state的監(jiān)控等。 state:頁面狀態(tài)管理容器對象。集中存儲Vue components中data對象的零散數(shù)據(jù),全局唯一,以進(jìn)行統(tǒng)一的狀態(tài)管理。頁面顯示所需的數(shù)據(jù)從該對象中進(jìn)行讀取,利用Vue的細(xì)粒度數(shù)據(jù)響應(yīng)機(jī)制來進(jìn)行高效的狀態(tài)更新。 getters:state對象讀取方法。圖中沒有單獨(dú)列出該模塊,應(yīng)該被包含在了render中,Vue Components通過該方法讀取全局state對象。 3.Vuex與localStorage vuex 是 vue 的狀態(tài)管理器,存儲的數(shù)據(jù)是響應(yīng)式的。但是并不會保存起來,刷新之后就回到了初始狀態(tài),具體做法應(yīng)該在vuex里數(shù)據(jù)改變的時(shí)候把數(shù)據(jù)拷貝一份保存到localStorage里面,刷新之后,如果localStorage里有保存的數(shù)據(jù),取出來再替換store里的state。
let defaultCity = "上海" try { // 用戶關(guān)閉了本地存儲功能,此時(shí)在外層加個(gè)try...catch if (!defaultCity){ defaultCity = JSON.parse(window.localStorage.getItem('defaultCity')) } }catch(e){} export default new Vuex.Store({ state: { city: defaultCity }, mutations: { changeCity(state, city) { state.city = city try { window.localStorage.setItem('defaultCity', JSON.stringify(state.city)); // 數(shù)據(jù)改變的時(shí)候把數(shù)據(jù)拷貝一份保存到localStorage里面 } catch (e) {} } } })
這里需要注意的是:由于vuex里,我們保存的狀態(tài),都是數(shù)組,而localStorage只支持字符串,所以需要用JSON轉(zhuǎn)換:
JSON.stringify(state.subscribeList); // array -> string JSON.parse(window.localStorage.getItem("subscribeList")); // string -> array 復(fù)制代碼
方法四、listeners
1.簡介
多級組件嵌套需要傳遞數(shù)據(jù)時(shí),通常使用的方法是通過vuex。但如果僅僅是傳遞數(shù)據(jù),而不做中間處理,使用 vuex 處理,未免有點(diǎn)大材小用。為此Vue2.4 版本提供了另一種方法----listeners

Hei?e KI -Werkzeuge

Undress AI Tool
Ausziehbilder kostenlos

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

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

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)

PHP und Vue: eine perfekte Kombination von Front-End-Entwicklungstools In der heutigen Zeit der rasanten Entwicklung des Internets ist die Front-End-Entwicklung immer wichtiger geworden. Da Benutzer immer h?here Anforderungen an das Erlebnis von Websites und Anwendungen stellen, müssen Frontend-Entwickler effizientere und flexiblere Tools verwenden, um reaktionsf?hige und interaktive Schnittstellen zu erstellen. Als zwei wichtige Technologien im Bereich der Front-End-Entwicklung k?nnen PHP und Vue.js in Kombination als perfekte Waffe bezeichnet werden. In diesem Artikel geht es um die Kombination von PHP und Vue sowie um detaillierte Codebeispiele, die den Lesern helfen sollen, diese beiden besser zu verstehen und anzuwenden

Als schnelle und effiziente Programmiersprache erfreut sich Go im Bereich der Backend-Entwicklung gro?er Beliebtheit. Allerdings assoziieren nur wenige Menschen die Go-Sprache mit der Front-End-Entwicklung. Tats?chlich kann die Verwendung der Go-Sprache für die Front-End-Entwicklung nicht nur die Effizienz verbessern, sondern Entwicklern auch neue Horizonte er?ffnen. In diesem Artikel wird die M?glichkeit der Verwendung der Go-Sprache für die Front-End-Entwicklung untersucht und spezifische Codebeispiele bereitgestellt, um den Lesern ein besseres Verst?ndnis dieses Bereichs zu erleichtern. In der traditionellen Frontend-Entwicklung werden h?ufig JavaScript, HTML und CSS zum Erstellen von Benutzeroberfl?chen verwendet

Vue.js eignet sich für kleine und mittelgro?e Projekte und schnelle Iterationen, w?hrend React für gro?e und komplexe Anwendungen geeignet ist. 1) Vue.js ist einfach zu bedienen und für Situationen geeignet, in denen das Team nicht ausreicht oder die Projektskala klein ist. 2) React hat ein reichhaltigeres ?kosystem und eignet sich für Projekte mit hoher Leistung und komplexen funktionalen Bedürfnissen.

In Front-End-Entwicklungsinterviews decken h?ufige Fragen ein breites Themenspektrum ab, darunter HTML/CSS-Grundlagen, JavaScript-Grundlagen, Frameworks und Bibliotheken, Projekterfahrung, Algorithmen und Datenstrukturen, Leistungsoptimierung, dom?nenübergreifende Anfragen, Front-End-Engineering, Designmuster sowie neue Technologien und Trends. Interviewerfragen sollen die technischen F?higkeiten, die Projekterfahrung und das Verst?ndnis des Kandidaten für Branchentrends beurteilen. Daher sollten Kandidaten in diesen Bereichen umfassend vorbereitet sein, um ihre F?higkeiten und Fachkenntnisse unter Beweis zu stellen.

Kombination von Golang und Front-End-Technologie: Um zu untersuchen, welche Rolle Golang im Front-End-Bereich spielt, sind spezifische Codebeispiele erforderlich. Mit der rasanten Entwicklung des Internets und mobiler Anwendungen ist die Front-End-Technologie immer wichtiger geworden. Auch in diesem Bereich kann Golang als leistungsstarke Back-End-Programmiersprache eine wichtige Rolle spielen. In diesem Artikel wird untersucht, wie Golang mit Front-End-Technologie kombiniert wird, und sein Potenzial im Front-End-Bereich anhand spezifischer Codebeispiele demonstriert. Die Rolle von Golang im Front-End-Bereich ist effizient, pr?gnant und leicht zu erlernen

Vue.js ist nicht schwer zu lernen, insbesondere für Entwickler mit einer JavaScript -Stiftung. 1) Sein progressives Design und das reaktionsschnelle System vereinfachen den Entwicklungsprozess. 2) Komponentenbasierte Entwicklung macht das Codemanagement effizienter. 3) Die Nutzungsbeispiele zeigen eine grundlegende und fortgeschrittene Verwendung. 4) H?ufige Fehler k?nnen durch VEDEVTOOLS debuggen werden. 5) Leistungsoptimierung und Best Practices, z. B. die Verwendung von V-IF/V-Shows und Schlüsselattributen, k?nnen die Anwendungseffizienz verbessern.

Vue.js wird haupts?chlich für die Front-End-Entwicklung verwendet. 1) Es handelt sich um ein leichtes und flexibles JavaScript-Framework, das sich auf den Aufbau von Benutzeroberfl?chen und einseitigen Anwendungen konzentriert. 2) Der Kern von Vue.js ist das reaktionsschnelle Datensystem, und die Ansicht wird automatisch aktualisiert, wenn sich die Daten ?ndert. 3) Es unterstützt die Komponentenentwicklung und die Benutzeroberfl?che kann in unabh?ngige und wiederverwendbare Komponenten aufgeteilt werden.

Zu den Hauptfunktionen von React geh?ren komponentiertes Denken, Staatsmanagement und virtuelles DOM. 1) Die Idee der Komponentierung erm?glicht es, die Benutzeroberfl?che in wiederverwendbare Teile aufzuteilen, um die Lesbarkeit und Wartbarkeit der Code zu verbessern. 2) Das staatliche Management verwaltet dynamische Daten durch Status und Requisiten und ?ndert sich ausl?sen UI -Updates. 3) Aktualisieren Sie die Benutzeroberfl?che virtuelle DOM -Optimierungsleistung durch die Berechnung des Mindestbetriebs der DOM -Replik im Speicher.
