Heim Web-Frontend js-Tutorial Wie verwende ich Vuex? Detaillierte Erläuterung der Vuex-Nutzungsschritte (mit Code)

Wie verwende ich Vuex? Detaillierte Erläuterung der Vuex-Nutzungsschritte (mit Code)

Apr 28, 2018 pm 01:37 PM
vuex

So verwenden Sie vuex: 1. Verwenden Sie das Vue-Gerüsttool, um das Projekt zu erstellen. 2. Verwenden Sie das npm-Paketverwaltungstool, um vuex zu installieren. 3. Erstellen Sie einen neuen Store-Ordner und eine neue Datei „store.js“. " unter dem Ordner file; 4. Fügen Sie vue und vuex in die Datei ein.

Wie verwende ich Vuex? Detaillierte Erläuterung der Vuex-Nutzungsschritte (mit Code)

Wie verwende ich Vuex? Dieses Mal erkläre ich Ihnen ausführlich die Schritte zur Verwendung von vuex (mit Code), welche Vorsichtsmaßnahmen bei der Verwendung von vuex gelten, und das Folgende ist ein praktischer Fall. Schauen wir uns das an.

Was ist Vuex?

vuex ist eine zentralisierte Zustandsverwaltungsarchitektur, die speziell für vue.js entwickelt wurde. Zustand? Ich verstehe darunter den Teil, in dem die Attribute in den Daten mit anderen Vue-Komponenten geteilt werden müssen, was als Zustand bezeichnet wird. Einfach ausgedrückt sind es die Attribute, die in den Daten gemeinsam genutzt werden müssen.

Vuex vorstellen (vorausgesetzt, das Projekt wurde mit dem Vue-Gerüsttool erstellt)

1. Verwenden Sie das npm-Paketverwaltungstool, um Vuex zu installieren. Geben Sie einfach den folgenden Befehl in die Steuerbefehlszeile ein.

 npm install vuex --save
Nach dem Login kopieren

Es ist zu beachten, dass hier –save hinzugefügt werden muss, da wir Ihr Paket in der Produktionsumgebung verwenden.

2. Erstellen Sie einen neuen Store-Ordner (dies ist nicht erforderlich), erstellen Sie eine neue Datei „store.js“ unter dem Ordner und fügen Sie unsere Vue und Vuex in die Datei ein.

 import Vue from 'vue';
 import Vuex from 'vuex';
Nach dem Login kopieren
Nach dem Login kopieren

3. Verwenden Sie unseren Vuex und referenzieren Sie ihn nach dem Import mit Vue.use.

 import Vue from 'vue';
 import Vuex from 'vuex';
Nach dem Login kopieren
Nach dem Login kopieren

Durch diese drei Schritte können wir dann auch dann Spaß haben, wenn Vuex erfolgreich referenziert wird.

4. Fügen Sie die neue Vuex-Datei

 import storeConfig from './vuex/store'
Nach dem Login kopieren

in main.js ein. 5. Fügen Sie dann das Store-Objekt hinzu, wenn Sie das Vue-Objekt instanziieren 🎜>

Machen wir eine Demo1 Jetzt fügen wir der Datei „store.js“ ein konstantes Objekt hinzu. Die Datei store.js ist die Datei, als wir vuex eingeführt haben.

 new Vue({
  el: '#app',
  router,
  store,//使用store
  template: '<App/>',
  components: { App }
 })
Nach dem Login kopieren

2. Verwenden Sie den Exportstandard, um den Code zu kapseln, damit er extern referenziert werden kann.

 const state = {
  count:1
 }
Nach dem Login kopieren

3. Erstellen Sie eine neue Vue-Vorlage mit dem Namen count.vue im Komponentenordner. In der Vorlage führen wir die soeben erstellte Datei store.js ein und verwenden

, um den Zählwert in der Vorlage auszugeben.

 export default new Vuex.Store({
  state
 });
Nach dem Login kopieren
{{$store.state.count}}4. Fügen Sie zwei Methoden hinzu, um den Status in der Datei „store.js“ zu ändern.
 <template>
  <p>
   <h2>{{msg}}</h2>
   <hr/>
   <h3>{{$store.state.count}}</h3>
  </p>
 </template>
 <script>
  import store from '@/vuex/store'
  export default{
   data(){
    return{
     msg:'Hello Vuex',
    }
   },
   store
  }
 </script>
Nach dem Login kopieren

Die Mutationen hier sind fest geschrieben, was bedeutet, dass sie geändert werden können. Sie müssen sich also keine Sorgen machen, dass die Art und Weise, wie wir den Wert des Zustands ändern möchten, in Mutationen geschrieben werden muss .

5. Fügen Sie der count.vue-Vorlage zwei Schaltflächen hinzu und rufen Sie die Methoden in Mutationen auf.

const mutations={
  add(state){
   state.count+=1;
  },
  reduce(state){
   state.count-=1;
  }
 }
Nach dem Login kopieren

Durch die Vorschau auf diese Weise können Sie die Anzahl in vuex addieren oder subtrahieren.

Statuszugriffsstatusobjekt const state, das nennen wir das Zugriffsstatusobjekt, es ist unser SPA (Single-Page-Anwendung) Gemeinsamer Wert in .

Das Lernstatusobjekt wird dem

internen Objekt

zugewiesen, d. h. der Wert in stoe.js wird dem Wert in den Daten in unserer Vorlage zugewiesen. Es gibt drei Zuweisungsmethoden

1. Direkte Zuweisung durch berechnete berechnete Attribute Das berechnete Attribut kann Operationen an den Werten in Daten ausführen Vor der Ausgabeänderung verwenden wir diese Funktion, um den Statuswert in store.js dem Datenwert in unserer Vorlage zuzuweisen.

 <p>
  <button @click="$store.commit(&#39;add&#39;)">+</button>
  <button @click="$store.commit(&#39;reduce&#39;)">-</button>
 </p>
Nach dem Login kopieren

Hier ist zu beachten, dass Sie im Satz

Folgendes schreiben müssen, sonst können Sie $store nicht finden. Diese Schreibweise ist leicht zu verstehen, aber schwieriger zu schreiben. Schauen wir uns die zweite Schreibweise an.

return this.$store.state.count

2. Wert über das MapState-Objekt zuweisen Wir müssen zuerst den Import verwenden, um MapState einzuführen.

 computed:{
  count(){
   return this.$store.state.count;
  }
 }
Nach dem Login kopieren

Dann schreiben Sie den folgenden Code in das berechnete Attribut:

import {mapState} from 'vuex';
Nach dem Login kopieren

Hier verwenden wir die ES6-Pfeilfunktion, um einen zu zählenden Wert zuzuweisen.

3. Weisen Sie den Wert über das Array von mapState zu.

 computed:mapState({
   count:state=>state.count //理解为传入state对象,修改state.count属性
  })
Nach dem Login kopieren
Dies ist die einfachste Art, ihn in tatsächlichen Projekten zu schreiben Dies wird häufig in der Entwicklung verwendet.

Mutations修改状态($store.commit( ))
Nach dem Login kopieren

Vuex提供了commit方法来修改状态,我们粘贴出Demo示例代码内容,简单回顾一下,我们在button上的修改方法。

 <button @click="$store.commit(&#39;add&#39;)">+</button>
 <button @click="$store.commit(&#39;reduce&#39;)">-</button>
Nach dem Login kopieren

store.js文件:

 const mutations={
  add(state){
   state.count+=1;
  },
  reduce(state){
   state.count-=1;
  }
 }
Nach dem Login kopieren

传值:这只是一个最简单的修改状态的操作,在实际项目中我们常常需要在修改状态时传值。比如上边的例子,是我们每次只加1,而现在我们要通过所传的值进行相加。其实我们只需要在Mutations里再加上一个参数,并在commit的时候传递就就可以了。我们来看具体代码:

现在store.js文件里给add方法加上一个参数n。

 const mutations={
  add(state,n){
   state.count+=n;
  },
  reduce(state){
   state.count-=1;
  }
 }
Nach dem Login kopieren

在Count.vue里修改按钮的commit( )方法传递的参数,我们传递10,意思就是每次加10.

 <p>
  <button @click="$store.commit(&#39;add&#39;,10)">+</button>
  <button @click="$store.commit(&#39;reduce&#39;)">-</button>
 </p>
Nach dem Login kopieren

模板获取Mutations方法

实际开发中我们也不喜欢看到$store.commit( )这样的方法出现,我们希望跟调用模板里的方法一样调用。
 例如:@click=”reduce” 就和没引用vuex插件一样。要达到这种写法,只需要简单的两部就可以了:

1、在模板count.vue里用import 引入我们的mapMutations:   

 import { mapState,mapMutations } from 'vuex';
Nach dem Login kopieren

2、在模板的<\script>标签里添加methods属性,并加入mapMutations

 methods:mapMutations([
   'add','reduce'
 ]),
Nach dem Login kopieren

通过上边两部,我们已经可以在模板中直接使用我们的reduce或者add方法了,就像下面这样。

 <button @click="reduce">-</button>
Nach dem Login kopieren

getters计算过滤操作

getters从表面是获得的意思,可以把他看作在获取数据之前进行的一种再编辑,相当于对数据的一个过滤和加工。你可以把它看作store.js的计算属性。

getters基本用法:

比如我们现在要对store.js文件中的count进行一个计算属性的操作,就是在它输出前,给它加上100.我们首先要在store.js里用const声明我们的getters属性。

 const getters = {
  count:function(state){
   return state.count +=100;
  }
 }
Nach dem Login kopieren

写好了gettters之后,我们还需要在Vuex.Store()里引入,由于之前我们已经引入了state和mutations,所以引入里有三个引入属性。代码如下,

 export default new Vuex.Store({
  state,mutations,getters
 })
Nach dem Login kopieren

在store.js里的配置算是完成了,我们需要到模板页对computed进行配置。在vue 的构造器里边只能有一个computed属性,如果你写多个,只有最后一个computed属性可用,所以要对上节课写的computed属性进行一个改造。改造时我们使用ES6中的展开运算符”…”。

 computed:{
  ...mapState(["count"]),
  count(){
   return this.$store.getters.count;
  }
 },
Nach dem Login kopieren

需要注意的是,你写了这个配置后,在每次count 的值发生变化的时候,都会进行加100的操作。

用mapGetters简化模板写法

我们都知道state和mutations都有map的引用方法把我们模板中的编码进行简化,我们的getters也是有的,我们来看一下代码。

首先用import引入我们的mapGetters

 import { mapState,mapMutations,mapGetters } from 'vuex';
Nach dem Login kopieren

在computed属性中加入mapGetters

 ...mapGetters(["count"])
Nach dem Login kopieren

actions异步修改状态

actions和之前讲的Mutations功能基本一样,不同点是,actions是异步的改变state状态,而Mutations是同步改变状态。至于什么是异步什么是同步这里我就不做太多解释了,如果你不懂自己去百度查一下吧。

在store.js中声明actions

actions是可以调用Mutations里的方法的,我们还是继续在上节课的代码基础上进行学习,在actions里调用add和reduce两个方法。

 const actions ={
  addAction(context){
   context.commit('add',10)
  },
  reduceAction({commit}){
   commit('reduce')
  }
 }
Nach dem Login kopieren

在actions里写了两个方法addAction和reduceAction,在方法体里,我们都用commit调用了Mutations里边的方法。细心的小伙伴会发现这两个方法传递的参数也不一样。

•ontext:上下文对象,这里你可以理解称store本身。
•{commit}:直接把commit对象传递过来,可以让方法体逻辑和代码更清晰明了。

模板中的使用

我们需要在count.vue模板中编写代码,让actions生效。我们先复制两个以前有的按钮,并改成我们的actions里的方法名,分别是:addAction和reduceAction。

  <p>
   <button @click="addAction">+</button>
   <button @click="reduceAction">-</button>
  </p>
Nach dem Login kopieren

改造一下我们的methods方法,首先还是用扩展运算符把mapMutations和mapActions加入。

  methods:{
    ...mapMutations([ 
      'add','reduce'
    ]),
    ...mapActions(['addAction','reduceAction'])
  },
Nach dem Login kopieren

你还要记得用import把我们的mapActions引入才可以使用。

增加异步检验

我们现在看的效果和我们用Mutations作的一模一样,肯定有的小伙伴会好奇,那actions有什么用,我们为了演示actions的异步功能,我们增加一个计时器(setTimeOut)延迟执行。在addAction里使用setTimeOut进行延迟执行。

  setTimeOut(()=>{context.commit(reduce)},3000);
  console.log('我比reduce提前执行');
Nach dem Login kopieren

我们可以看到在控制台先打印出了‘我比reduce提前执行'这句话。

module模块组

随着项目的复杂性增加,我们共享的状态越来越多,这时候我们就需要把我们状态的各种操作进行一个分组,分组后再进行按组编写。那今天我们就学习一下module:状态管理器的模块组操作。

声明模块组:

在vuex/store.js中声明模块组,我们还是用我们的const常量的方法声明模块组。代码如下:

  const moduleA={
    state,mutations,getters,actions
  }
Nach dem Login kopieren

声明好后,我们需要修改原来 Vuex.Stroe里的值:

  export default new Vuex.Store({
    modules:{a:moduleA}
  })
Nach dem Login kopieren

在模板中使用

现在我们要在模板中使用count状态,要用插值的形式写入。 

<h3>{{$store.state.a.count}}</h3>
Nach dem Login kopieren

如果想用简单的方法引入,还是要在我们的计算属性中rutrun我们的状态。写法如下:

  computed:{
    count(){
      return this.$store.state.a.count;
    }
  },
Nach dem Login kopieren

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

操作render执行有哪些方法

js实现复制文本文件功能(步奏详解)

Das obige ist der detaillierte Inhalt vonWie verwende ich Vuex? Detaillierte Erläuterung der Vuex-Nutzungsschritte (mit Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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 KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

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)

Best Practices für die Verwendung von Vuex zur Verwaltung des globalen Status in Vue2.x Best Practices für die Verwendung von Vuex zur Verwaltung des globalen Status in Vue2.x Jun 09, 2023 pm 04:07 PM

Vue2.x ist derzeit eines der beliebtesten Front-End-Frameworks, das Vuex als Lösung für die Verwaltung des globalen Status bereitstellt. Durch die Verwendung von Vuex kann die Statusverwaltung klarer und einfacher zu warten sein. Im Folgenden werden die Best Practices von Vuex vorgestellt, um Entwicklern dabei zu helfen, Vuex besser zu nutzen und die Codequalität zu verbessern. 1. Verwenden Sie einen modularen Organisationsstatus, um alle Status der Anwendung zu verwalten und den Status aus den Komponenten zu extrahieren, wodurch die Statusverwaltung klarer und verständlicher wird. Bei Anwendungen mit vielen Zuständen müssen Module verwendet werden

Wie kann das Problem „Fehler: [vuex] ändert den Vuex-Speicherstatus außerhalb von Mutationshandlern nicht' gelöst werden, wenn Vuex in einer Vue-Anwendung verwendet wird? Wie kann das Problem „Fehler: [vuex] ändert den Vuex-Speicherstatus außerhalb von Mutationshandlern nicht' gelöst werden, wenn Vuex in einer Vue-Anwendung verwendet wird? Jun 24, 2023 pm 07:04 PM

In Vue-Anwendungen ist die Verwendung von Vuex eine gängige Methode zur Zustandsverwaltung. Bei der Verwendung von vuex kann es jedoch manchmal zu einer Fehlermeldung kommen: „Fehler:[vuex]donotmutatevuexstorestateoutsidemutationhandlers“ Was bedeutet diese Fehlermeldung? Warum erscheint diese Fehlermeldung? Wie kann dieser Fehler behoben werden? In diesem Artikel wird dieses Problem ausführlich behandelt. Die Fehlermeldung enthält

So verwenden Sie Vuex in Vue3 So verwenden Sie Vuex in Vue3 May 14, 2023 pm 08:28 PM

Was macht Vuex? Vue-Beamter: Statusverwaltungstool Was ist Statusverwaltung? Der Status muss von mehreren Komponenten gemeinsam genutzt werden, und er reagiert. Sobald er sich ändert, ändert sich alles. Zum Beispiel einige global verwendete Statusinformationen: Benutzeranmeldestatus, Benutzername, geografische Standortinformationen, Artikel im Warenkorb usw. Derzeit benötigen wir ein solches Tool für die globale Statusverwaltung, und Vuex ist ein solches Tool. Einzelseiten-Statusverwaltung Ansicht–>Aktionen–>Status Ansichtsebene (Ansicht) löst Aktion (Aktion) aus, um den Status (Status) zu ändern, und reagiert zurück auf Ansichtsebene (Ansicht) vuex (Vue3.

Wie löse ich das Problem „Fehler: [vuex] unbekannter Aktionstyp: xxx' bei der Verwendung von vuex in einer Vue-Anwendung? Wie löse ich das Problem „Fehler: [vuex] unbekannter Aktionstyp: xxx' bei der Verwendung von vuex in einer Vue-Anwendung? Jun 25, 2023 pm 12:09 PM

In Vue.js-Projekten ist Vuex ein sehr nützliches Statusverwaltungstool. Es hilft uns, den Status zwischen mehreren Komponenten zu teilen und bietet eine zuverlässige Möglichkeit, Statusänderungen zu verwalten. Bei der Verwendung von vuex tritt jedoch manchmal der Fehler „Fehler:[vuex]unknownactiontype:xxx“ auf. In diesem Artikel werden die Ursache und Lösung dieses Fehlers erläutert. 1. Fehlerursache Bei der Verwendung von vuex müssen wir einige Aktionen und mu definieren

Erfahren Sie mehr über die Implementierungsprinzipien von vuex Erfahren Sie mehr über die Implementierungsprinzipien von vuex Mar 20, 2023 pm 06:14 PM

Wie sollten Sie antworten, wenn Sie in einem Interview nach dem Implementierungsprinzip von vuex gefragt werden? Der folgende Artikel vermittelt Ihnen ein detailliertes Verständnis des Implementierungsprinzips von vuex. Ich hoffe, er wird Ihnen hilfreich sein!

Wie kann das Problem „TypeError: Eigenschaft ‚xxx' von undefiniert kann nicht gelesen werden' gelöst werden, wenn Vuex in einer Vue-Anwendung verwendet wird? Wie kann das Problem „TypeError: Eigenschaft ‚xxx' von undefiniert kann nicht gelesen werden' gelöst werden, wenn Vuex in einer Vue-Anwendung verwendet wird? Aug 18, 2023 pm 09:24 PM

Die Verwendung von Vuex in Vue-Anwendungen ist ein sehr häufiger Vorgang. Bei der Verwendung von Vuex wird jedoch gelegentlich die Fehlermeldung „TypeError: Cannotreadproperty'xxx'ofundefined“ angezeigt. Diese Fehlermeldung bedeutet, dass die undefinierte Eigenschaft „xxx“ nicht gelesen werden kann, was zu einem Programmfehler führt. Der Grund für dieses Problem liegt tatsächlich auf der Hand: Beim Aufrufen eines bestimmten Attributs von Vuex wird dieses Attribut nicht korrekt festgelegt.

So verwenden Sie Vuex in Vue3+Vite So verwenden Sie Vuex in Vue3+Vite Jun 03, 2023 am 09:10 AM

Spezifische Schritte: 1. Installieren Sie vuex (vue3 empfohlen 4.0+) pnpmivuex-S2, konfigurieren Sie die globale Konfiguration von importstorefrom'@/store'//hx-app in main.js constapp=createApp(App)app.use(store) 3 . Erstellen Sie hier neue verwandte Ordner und Dateien, um verschiedene Seiten und Dateien zu platzieren, und verwenden Sie stattdessen eine getters.jsindex.js-Kerndatei von

Wie verwende ich Vuex für die Komponentenkommunikation in Vue? Wie verwende ich Vuex für die Komponentenkommunikation in Vue? Jul 19, 2023 pm 06:16 PM

Wie verwende ich Vuex für die Komponentenkommunikation in Vue? Vue ist ein beliebtes JavaScript-Framework, das ein komponentenbasiertes Entwicklungsmodell verwendet und es uns ermöglicht, komplexe Anwendungen einfacher zu erstellen. Im Komponentenentwicklungsprozess von Vue stoßen wir häufig auf Situationen, die eine Kommunikation zwischen verschiedenen Komponenten erfordern. Vuex ist das von Vue offiziell empfohlene Statusverwaltungstool. Es bietet einen zentralen Speichermanager und löst das Problem der Kommunikation zwischen Komponenten. In diesem Artikel wird erläutert, wie Sie Vuex für die Komponentenkommunikation in Vue verwenden

See all articles