Vuex实现计数器以及列表展示效果
程序员文章站
2022-06-14 12:57:35
本篇教程将以计数器及列表展示两个例子来讲解vuex的简单用法。
本案例github
从安装到启动初始页面的过程都直接跳过。注意安装时选择需要路由。
首先,...
本篇教程将以计数器及列表展示两个例子来讲解vuex的简单用法。
本案例github
从安装到启动初始页面的过程都直接跳过。注意安装时选择需要路由。
首先,src目录下新建store目录及相应文件,结构如下:
index.js文件内容:
import vue from "vue" import vuex from 'vuex' vue.use(vuex); //务必在new vuex.store之前use一下 export default new vuex.store({ state:{ count:0 //计数器的count }, mutations:{ increment(state){ state.count++ } } })
src下的main.js里注册store
new vue({ el: '#app', router, store, //注册store components: { app }, template: '<app/>' });
components文件夹内新建num.vue组件,内容如下
<template> <div> <input type="button" value="+" @click="incr" /> <input type="text" id="input" v-model="count"/> <input type="button" value="-"/> <br/> <router-link to="/list">列表demo</router-link> </div> </template> <script> import store from '../store' export default { computed:{ count:{ get:function () { return store.state.count }, set:function (val) { store.state.count = val } } }, methods:{ incr(){ // store.commit("increment") store.commit("increment") //触发修改 } } } </script> <!-- add "scoped" attribute to limit css to this component only --> <style scoped> </style>
router文件夹内配置路由:
import vue from 'vue' import router from 'vue-router' import num from '../components/num' import list from '../components/list' vue.use(router) export default new router({ routes: [ { path:'/num', component:num }, { path:"*", redirect:"/num" } ] })
完成后启动,即可看到结果。计数器演示完成。
现在开始列表演示。
src目录下新建api文件夹,再新建api文件。
api/cover.js:
const _cover = [ {"id": 1, "title": "ipad 4 mini", "price": 500.01, "inventory": 2}, {"id": 2, "title": "h&m t-shirt white", "price": 10.99, "inventory": 10}, {"id": 3, "title": "charli xcx - sucker cd", "price": 19.99, "inventory": 5} ]; export default { getcover(cb) { settimeout(() => cb(_cover), 100); /* $.get("/api/data",function (data) { console.log(data); })*/ }, }
修改store/modules/cover.js:(定义数据模型)
import cover from '../../api/cover' const state = { all:[] }; const getters={ allcover:state=>state.all //getter用来提供访问接口 }; const actions = { getallcover({commit}){ cover.getcover(covers=>{ commit('setcover',covers) //触发setcover修改。 }) }, removecover({commit},cover){ commit('removecover',cover) } }; const mutations = { //mutations用来修改state。 setcover(state,covers){ state.all = covers }, removecover(state,cover){ console.log(cover.id); state.all = state.all.filter(function (ocover) { return ocover.id !== cover.id }) } }; export default { state,getters,actions,mutations }
store内的index.js中注册数据模型:
import vue from "vue" import vuex from 'vuex' import cover from './modules/cover' vue.use(vuex); //务必在new vuex.store之前use一下 export default new vuex.store({ modules:{ cover //注册cover数据模型 }, state:{ count:0 //计数器的count }, mutations:{ increment(state){ state.count++ } } })
components文件夹内新建list.vue组件,内容如下:
<template> <div class="list"> <ul> <li v-for="cover in covers" @click="removecover(cover)"> {{cover.title}} </li> </ul> <p> {{covers}} </p> <h2>请尝试点击li。</h2> <router-link to="/num">计数器demo</router-link> </div> </template> <script> import {mapgetters,mapactions} from 'vuex'; export default { computed:mapgetters({ covers:"allcover" //利用module的getter获得数据 }), methods:mapactions([ 'removecover' //利用module的action删除数据 ]), created(){ this.$store.dispatch('getallcover') //调用cover数据模型的getallcover action 用来初始化列表数据。 } } </script> <!-- add "scoped" attribute to limit css to this component only --> <style scoped> .list{ text-align: left; } </style>
路由中注册新组件:
import vue from 'vue' import router from 'vue-router' import num from '../components/num' import list from '../components/list' vue.use(router) export default new router({ routes: [ { path:'/num', component:num }, { path:'/list', component:list }, { path:"*", redirect:"/num" } ] })
完成后访问http://localhost:8080/#/list,即可看到结果。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: vue加载自定义的js文件方法