Maison interface Web js tutoriel Analyse du projet pratique vuex state+mapState

Analyse du projet pratique vuex state+mapState

Jun 07, 2018 am 11:40 AM
state vuex

Cette fois, je vais vous apporter une analyse du projet actuel de vuex state+mapState Quelles sont les précautions pour vuex state+mapState Ce qui suit est un cas pratique, jetons un coup d'oeil.

Utilisez d'abord vue cli pour créer votre propre projet vue

1.npm i -g vue-cli
2.vue init webpack sell (sell, c'est vous Nom du projet)
3. Entrez jusqu'au bout (au cours de ce processus, il vous sera demandé si vous souhaitez installer certains packages dépendants, tels que vue-router, la vérification grammaticale es6, etc., sélectionnez O/N en fonction de vos habitudes personnelles ou loisirs)
4.npm i (c'est le package de dépendances pour le projet d'installation)
5.npm run dev (démarrez votre projet vue) À ce moment, si vous voyez le logo vue sur la page, cela signifie que la base de votre projet vue a été construite et terminée, vous pouvez alors supprimer les composants inutiles
6. Webpack sell n'installe pas vuex par défaut, vous devez donc appuyer deux fois sur ctrl+c sur la ligne de commande ; terminez le serveur, npm install vuex –save pour installer vuex.
7. Créez un nouveau composant vue dans votre répertoire src (vous pouvez le nommer comme vous le souhaitez, soyez simplement heureux). utilisé comme conteneur principal et affiche uniquement le contenu
8. Créez ensuite un nouveau Appelez le composant comme vous voulez (je l'appellerai ici le composant d'affichage) pour accepter l'état dans l'état
9. Ensuite, nous créons un nouveau dossier appelé store dans le répertoire src et créons un nouveau fichier js sous le magasin appelé test .js (le magasin ici est notre entrepôt de données front-end) utilise vuex pour la gestion de l'état. Store est le cœur de vuex, il s'appelle donc store. Créez un nouveau fichier store dans le répertoire src et créez un fichier test.js dans le répertoire store (comme indiqué ci-dessous). Vous pouvez voir qu'avant d'utiliser vuex, vous devez dire à vue de l'utiliser, Vue.use(Vuex); Nous n'avons qu'un seul nombre de variables à gérer ici, donc lors de la création de l'objet store, transmettez les paramètres au constructeur, il n'y a qu'un seul nombre de variables à gérer. un compte sous l'état et initialisé à 0.

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const store = new Vuex.Store({
 state: {
 count: 0
 }
export default store
Copier après la connexion

Maintenant, tous les états, c'est-à-dire les variables, sont placés dans test.js, alors comment notre composant peut-il obtenir la valeur de modification de l'état ? Il y a deux étapes à opérer ici

1. Vue fournit un mécanisme d'injection, qui consiste à injecter notre objet store dans l'instance racine. L'instance racine de vue est le nouveau constructeur Vue, et dans tous les sous-composants, this.$store pointe vers l'objet store. Dans test.js, nous exportons le magasin et le magasin a été exposé. Le nouveau Vue() est dans main.js, nous pouvons donc directement introduire le magasin dans main.js et l'injecter.

import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store/test'
Vue.config.productionTip = false
/* eslint-disable no-new */
new Vue({
 el: '#app',
 router,
 store,
 template: '<App/>',
 components: { App }
})
Copier après la connexion

2. Dans les composants enfants, utilisez l'attribut calculé. L'attribut calculé est automatiquement mis à jour en fonction de ses dépendances. Ainsi, tant que l'état dans le magasin change, il changera automatiquement. Apportez les modifications suivantes dans display.vue. This.$store dans le sous-composant pointe vers l'objet store. Nous modifions le nombre dans test.js à 8, et il devient 8 sur la page.

<template>
 <p>
  <h3>Count is {{count}}</h3>
 </p>
</template>
<script>
 export default {
  computed: {
   count () {
    return this.$store.state.count 
   }
  }
 }
</script>
Copier après la connexion

3. La valeur d'état peut être obtenue via l'attribut calculé, mais chaque attribut (tel que le nombre) dans le composant est une fonction s'il y en a 10, alors 10 fonctions doivent être écrites, et. répété Il n'est pas très pratique d'écrire return this.$store.state 10 fois. Vue fournit la fonction mapState, qui mappe l'état directement à nos composants.

Bien sûr, vous devez introduire mapState avant de l'utiliser. Il peut être utilisé de deux manières, soit en acceptant un objet, soit en acceptant un tableau. Toujours sous le composant display.vue.

L'utilisation de l'objet est la suivante :

<script>
 import {mapState} from "vuex"; // 引入mapState 
 export default {
      // 下面这两种写法都可以
  computed: mapState({
   count: state => state.count // 组件内的每一个属性函数都会获得一个默认参数state, 然后通过state 直接获取它的属性更简洁  
   count: 'count'         // 'count' 直接映射到state 对象中的count, 它相当于 this.$store.state.count,
  })
 }
</script>
Copier après la connexion

La méthode du tableau est la suivante :

<script>
 import {mapState} from "vuex";
 export default {
  computed: mapState([ // 数组
   "count"
  ])
 }
</script>
Copier après la connexion

4, Il y a une dernière question, et si nous aussi avez-vous calculé des attributs à l'intérieur de nos composants ? Il n'appartient pas à mapState. Ensuite, nous utilisons la segmentation d'objets pour diviser les objets générés par la fonction mapState en un par un. Tout comme au début, nous avons répertorié les attributs calculés un par un. S'il y a 10 attributs, nous écrirons 10 fonctions.

... dans es6 est utilisé pour le fractionnement, mais il ne peut diviser que les tableaux. Il peut diviser des objets dans ECMAScript stage-3, donc babel-stage-3 est également utilisé à ce moment-là ; npm install babel-preset-stage-3 --save-dev Une fois l'installation terminée, n'oubliez pas d'ajouter. babel dans babelrc Dans le fichier de configuration, écrivez stage-3,

, sinon une erreur sera toujours signalée. Ajoutez une balise p à la page pour afficher la familiarité de calcul de notre composant

babelrc

{
 "presets": [
 ["env", {
  "modules": false,
  "targets": {
  "browsers": ["> 1%", "last 2 versions", "not ie <= 8"]
  }
 }],
 "stage-3"
 ],
 "plugins": ["transform-runtime"],
 "env": {
 "test": {
  "presets": ["env", "stage-3"],
  "plugins": ["istanbul"]
 }
 }
}
Copier après la connexion

composant display.vue après modifications

<template>
 <p>
  <h3>Count is {{count}}</h3>
  <p>组件自己的内部计算属性 {{ localComputed }}</p>
 </p>
</template>
<script>
 import {mapState} from "vuex";
 export default {
  computed: {
   localComputed () {
    return this.count + 10;
   },
   ...mapState({
    count: "count"
   })
  } 
 }
</script>
Copier après la connexion

Changez state.count dans test.js en 10 et voyez l'effet

Jetons un coup d'œil à l'utilisation de mapState dans Vuex

J'ai rencontré un piège lors de l'utilisation de Vuex aujourd'hui. On peut aussi dire que c'est ma propre ignorance. Après avoir longtemps lutté, j'ai finalement découvert l'erreur dans mon code. C'est vraiment tonitruant~~~~~~

index.js

import Vue from 'vue'
import Vuex from 'vuex'
import mutations from './mutations'
import actions from './action'
import getters from './getters'
Vue.use(Vuex)
const state = {
 userInfo: { phone: 111 }, //用户信息
 orderList: [{ orderno: '1111' }], //订单列表
 orderDetail: null, //订单产品详情
 login: false, //是否登录
}
export default new Vuex.Store({
 state,
 getters,
 actions,
 mutations,
})
computed: {
   ...mapState([
    'orderList',
    'login'
   ]),
  }, 
  mounted(){ 
   console.log(typeof orderList); ==>undefind
   console.log(typeof this.orderList)==>object
  }
Copier après la connexion

mapState通过扩展运算符将store.state.orderList 映射this.orderList  这个this 很重要,这个映射直接映射到当前Vue的this对象上。

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

推荐阅读:

如何操作Vue做出proxy代理

使用jquery获取上传文件具体内容

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Meilleures pratiques d'utilisation de Vuex pour gérer l'état global dans Vue2.x Meilleures pratiques d'utilisation de Vuex pour gérer l'état global dans Vue2.x Jun 09, 2023 pm 04:07 PM

Vue2.x est actuellement l'un des frameworks frontaux les plus populaires, qui fournit Vuex comme solution pour gérer l'état global. L'utilisation de Vuex peut rendre la gestion des états plus claire et plus facile à maintenir. Les meilleures pratiques de Vuex seront présentées ci-dessous pour aider les développeurs à mieux utiliser Vuex et à améliorer la qualité du code. 1. Utilisez l'état d'organisation modulaire. Vuex utilise une seule arborescence d'état pour gérer tous les états de l'application, extrayant l'état des composants, rendant la gestion des états plus claire et plus facile à comprendre. Dans les applications avec beaucoup d'états, des modules doivent être utilisés

Comment utiliser Vuex dans Vue3 Comment utiliser Vuex dans Vue3 May 14, 2023 pm 08:28 PM

Que fait Vuex ? Vue officielle : outil de gestion d'état Qu'est-ce que la gestion d'état ? L'état doit être partagé entre plusieurs composants, et il est réactif. Un seul changement change tout. Par exemple, certaines informations d'état utilisées à l'échelle mondiale : statut de connexion de l'utilisateur, nom d'utilisateur, informations de localisation géographique, articles dans le panier, etc. À l'heure actuelle, nous avons besoin d'un tel outil pour la gestion globale de l'état, et Vuex est un tel outil. Gestion de l'état d'une seule page Vue–>Actions–>La couche de vue d'état (vue) déclenche une action (action) pour changer d'état (état) et répond à la couche de vue (vue) vuex (Vue3.

Comment résoudre le problème « Erreur : [vuex] ne mute pas l'état du magasin vuex en dehors des gestionnaires de mutation lors de l'utilisation de vuex dans une application Vue ? Comment résoudre le problème « Erreur : [vuex] ne mute pas l'état du magasin vuex en dehors des gestionnaires de mutation lors de l'utilisation de vuex dans une application Vue ? Jun 24, 2023 pm 07:04 PM

Dans les applications Vue, l'utilisation de vuex est une méthode courante de gestion d'état. Cependant, lors de l'utilisation de vuex, nous pouvons parfois rencontrer un tel message d'erreur : "Erreur : [vuex]donotmutatevuexstorestateoutsidemutationhandlers." Que signifie ce message d'erreur ? Pourquoi ce message d'erreur apparaît-il ? Comment corriger cette erreur ? Cet article abordera ce problème en détail. Le message d'erreur contient

En savoir plus sur les principes de mise en œuvre de vuex En savoir plus sur les principes de mise en œuvre de vuex Mar 20, 2023 pm 06:14 PM

Lorsqu'on vous pose une question lors d'un entretien sur le principe de mise en œuvre de vuex, que devez-vous répondre ? L'article suivant vous donnera une compréhension approfondie du principe d'implémentation de vuex. J'espère qu'il vous sera utile !

Comment résoudre le problème « Erreur : [vuex] type d'action inconnu : xxx » lors de l'utilisation de vuex dans une application Vue ? Comment résoudre le problème « Erreur : [vuex] type d'action inconnu : xxx » lors de l'utilisation de vuex dans une application Vue ? Jun 25, 2023 pm 12:09 PM

Dans les projets Vue.js, vuex est un outil de gestion d'état très utile. Il nous aide à partager l'état entre plusieurs composants et fournit un moyen fiable de gérer les changements d'état. Mais lorsque vous utilisez vuex, vous rencontrerez parfois l'erreur "Erreur : [vuex]unknownactiontype:xxx". Cet article expliquera la cause et la solution de cette erreur. 1. Cause de l'erreur Lors de l'utilisation de vuex, nous devons définir certaines actions et mu

Comment résoudre le problème « TypeError : Impossible de lire la propriété 'xxx' de non définie » lors de l'utilisation de vuex dans l'application Vue ? Comment résoudre le problème « TypeError : Impossible de lire la propriété 'xxx' de non définie » lors de l'utilisation de vuex dans l'application Vue ? Aug 18, 2023 pm 09:24 PM

Utiliser Vuex dans les applications Vue est une opération très courante. Cependant, parfois lors de l'utilisation de Vuex, vous rencontrerez le message d'erreur « TypeError : Cannotreadproperty'xxx'ofundefined ». Ce message d'erreur signifie que la propriété non définie « xxx » ne peut pas être lue, ce qui entraîne une erreur de programme. La raison de ce problème est en fait très évidente. C'est parce que lors de l'appel d'un certain attribut de Vuex, cet attribut n'est pas correctement défini.

Comment utiliser vuex dans vue3+vite Comment utiliser vuex dans vue3+vite Jun 03, 2023 am 09:10 AM

Étapes spécifiques : 1. Installez vuex (vue3 recommandé 4.0+) pnpmivuex-S2, configurez la configuration globale de importstorefrom'@/store'//hx-app dans main.js constapp=createApp(App)app.use(store) 3 . Créez de nouveaux dossiers et fichiers associés. Ici, configurez plusieurs js dans différents modules vuex pour placer différentes pages et fichiers, puis utilisez un fichier principal getters.jsindex.js à la place. de

Comment résoudre le problème « Erreur : « xxx » a déjà été déclaré comme propriété de données. » lors de l'utilisation de vuex dans une application Vue ? Comment résoudre le problème « Erreur : « xxx » a déjà été déclaré comme propriété de données. » lors de l'utilisation de vuex dans une application Vue ? Jun 24, 2023 pm 08:46 PM

Dans le processus de développement des applications Vue, il est très courant d'utiliser vuex pour gérer l'état des applications. Cependant, lors du processus d'utilisation de vuex, nous pouvons parfois rencontrer un tel message d'erreur : "Erreur : 'xxx'hasalreadybeendeclaredasadataproperty." Ce message d'erreur semble très déroutant, mais il est en fait dû à l'utilisation de doublons dans la variable du composant Vue. noms pour définir les attributs de données et vuex

See all articles