Cette fois, je vais vous montrer comment utiliser vuex state et mapState, et quelles sont les précautions pour utiliser vuex state et mapState. Ce qui suit est un cas pratique, jetons un coup d'œil.
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 installer le projet)
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. Ensuite, créez-en un nouveau. Appelez le composant comme vous voulez (je l'appellerai le composant affichage ici) 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 dossier sous le magasin. Un fichier js 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 nouveau test dans le fichier js (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
, state Il n'y a qu'un seul décompte ci-dessous, et il est initialisé à 0.
import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ state: { count: 0 } export default store
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 } })
<template> <p> <h3>Count is {{count}}</h3> </p> </template> <script> export default { computed: { count () { return this.$store.state.count } } } </script>
<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>
<script> import {mapState} from "vuex"; export default { computed: mapState([ // 数组 "count" ]) } </script>
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 composantbabelrc
{ "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"] } } }
<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>
Jetons un coup d'œil à l'utilisation de mapState dans Vuex
今天使用Vuex的时候遇到一个坑,也可以说是自己的无知吧,折腾了好久,终于发现自己代码的错误了。真是天雷滚滚~~~~~~
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 }
mapState通过扩展运算符将store.state.orderList 映射this.orderList 这个this 很重要,这个映射直接映射到当前Vue的this对象上。
所以通过this都能将这些对象点出来,同理,mapActions, mapMutations都是一样的道理。牢记~~~
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
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!