Heim >Web-Frontend >js-Tutorial >Was sind die Eimer der Vue-Familie?

Was sind die Eimer der Vue-Familie?

angryTom
angryTomOriginal
2019-07-20 16:57:4715988Durchsuche

Was sind die Eimer der Vue-Familie?

Empfohlene Tutorials: VUE.JS-Tutorial

Vue hat die berühmte Family-Bucket-Serie , einschließlich vue-router, vuex, vue-resource. In Verbindung mit dem Build-Tool vue-cli und dem sass-Stil ist es die Kernkomponente eines vollständigen Vue-Projekts.

Um es zusammenzufassen:

1. Projektkonstruktionstool

2. Routing

 3. Statusverwaltung

 4. http-Anfragetool.

Das Folgende ist eine separate Einführung zu

Vorwort: Vues zwei Kernideen: Komponentisierung und datengesteuert. Komponentisierung: Teilen Sie das Ganze in wiederverwendbare Einzelpersonen auf, datengesteuert: Beeinflussen Sie die Stücklistenanzeige direkt durch Datenänderungen und vermeiden Sie DOM-Operationen.

1. Vue-cli ist das Gerüst, um diese einseitige Anwendung schnell zu erstellen,

# 全局安装 vue-cli
$ npm install --global vue-cli
# 创建一个基于 webpack 模板的新项目
$ vue init webpack my-project
# 安装依赖,走你
$ 
cd my-project
$ npm install
$ npm run dev

2. vue- router

Installation: npm installvue-router

Wenn Sie es in einem modularen Projekt verwenden, müssen Sie die Routing-Funktion explizit über Vue.use() installieren:

import Vue from'vue'
import VueRouter from'vue-router'
Vue.use(VueRouter)

Beachten Sie außerdem, dass Sie während der Verwendung das Übergangsattribut von Vue verwenden können, um den Effekt des Seitenwechsels darzustellen.

3. vuex

Das von vuex speziell für vue.js-Anwendungen entwickelte Zustandsmanagement kann als globales Datenmanagement verstanden werden. Vuex besteht hauptsächlich aus fünf Teilen: Zustandsaktion, Mutation, Getter und Mudle.

Der Verwendungsprozess ist: Die oben genannten vier Teile können direkt in der Komponente aufgerufen werden, mit Ausnahme von Mudle,

1, Zustand

Ähnlich wie bei den Daten Verwenden Sie das Vue-Objekt, um Daten und Status zu speichern. Die gespeicherten Daten reagieren. Wenn sich die Daten ändern, ändern sich auch die Komponenten, die auf die Daten angewiesen sind.

Beispiele für zwei Möglichkeiten, den Status abzurufen:

1.store.getters['getRateUserInfo']

2. ...mapGetters({

UserInfo: 'login/UserInfo', // Benutzerinformationen

menuList: 'getMenuList', // Frachtratengenehmigung genehmigen

RateUserInfo: 'getRateUserInfo' // Benutzerinformationen bewerten

})

Hinweis: Globaler Zustand und Getter können über „mapState“ den berechneten Eigenschaften der aktuellen Komponente zugeordnet werden.

2. Aktionen

Aktion wird durch die Methode store.dispatch ausgelöst: Aktion unterstützt asynchrone Aufrufe (API kann aufgerufen werden), Mutationen unterstützen nur die Operationssynchronisation und die Bei der eingereichten Aktion handelt es sich eher um eine Mutation als um eine direkte Zustandsänderung.

Zum Beispiel:

const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment (state) {
      state.count++
    }
  },
  actions: {
    increment (context) {
      context.commit('increment')
    }
  }
})

Die Action-Funktion akzeptiert ein Kontextobjekt mit denselben Methoden und Eigenschaften wie die Store-Instanz, sodass Sie context.commit aufrufen können, um eine Mutation zu übermitteln oder Kontext zu übergeben. Zustand und Kontext-Getter, um Zustand und Getter zu erhalten.

In der Praxis verwenden wir häufig die ES2015-Parameterdestrukturierung, um den Code zu vereinfachen (insbesondere, wenn wir Commit mehrmals aufrufen müssen):

3 🎜>Jede Mutation hat einen String-Ereignistyp (Typ) und eine Rückruffunktion (Handler). Mit dieser Rückruffunktion nehmen wir tatsächlich die Zustandsänderungen vor und sie akzeptiert den Zustand als ersten Parameter.

4. Getter

Vuex ermöglicht es uns, „Getter“ im Store zu definieren (die als berechnete Eigenschaften des Stores betrachtet werden können). Genau wie berechnete Eigenschaften wird der Rückgabewert eines Getters entsprechend seinen Abhängigkeiten zwischengespeichert und nur dann neu berechnet, wenn sich seine Abhängigkeitswerte ändern

const getters = {
  getRateInitData: state => state.rateInitData,
  getchooseRateObj: state => state.chooseRateObj,
  getSearchRateParams: state => state.searchRateParams,
  getSearchRateResult: state => state.searchRateResult,
  getRateUserInfo: state => state.RateUserInfo,
  getMenuList: state => state.menuList,
  getRateQueryParams: state => state.rateQueryParams,
  getRateQueryResult: state => state.rateQueryResult,
  getCheckRateDetailParams: state => state.checkRateDetailParams,
  getReferenceCondition: state => state.referenceCondition,
  getWaitApprovalParams: state => state.waitApprovalParams
}

 mapGetters-Hilfsfunktion

Die MapGetters-Hilfsfunktion Die Funktion ordnet die Getter im Store lediglich lokal berechneten Eigenschaften zu:

4. axios

Axios ist ein offizielles http-Anforderungspaket empfiehlt die Verwendung von axios für http-Aufrufe.

Installation:

npm install axios --save

Beispiel:

1. Senden Sie eine GET-Anfrage

//通过给定的ID来发送请求
axios.get('/user?ID=12345')
  .then(function(response){
    console.log(response);
  })
  .catch(function(err){
    console.log(err);
  });
//以上请求也可以通过这种方式来发送
axios.get('/user',{
  params:{
    ID:12345
  }
})
.then(function(response){
  console.log(response);
})
.catch(function(err){
  console.log(err);
});
2、发送一个POST请求
axios.post('/user',{
  firstName:'Fred',
  lastName:'Flintstone'
})
.then(function(res){
  console.log(res);
})
.catch(function(err){
  console.log(err);
});

Das obige ist der detaillierte Inhalt vonWas sind die Eimer der Vue-Familie?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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
Vorheriger Artikel:Die Rolle von console.log()Nächster Artikel:Die Rolle von console.log()