美文网首页
vuex的使用,vuex辅助函数、muduld的详解(文章下边)

vuex的使用,vuex辅助函数、muduld的详解(文章下边)

作者: 是嗯哼小仙女呀 | 来源:发表于2020-10-07 11:10 被阅读0次

    1)什么事Vuex

        Vuex是一个专为Vue.js应用程序开发的状态管理模式---所有页面共享的变量

    2)Vuex在什么情况下进行使用

    在项目过大的时候采取使用,项目量较小的时候是繁琐冗余的
    官网的说
    如果您不打算开发大型单页应用,使用 Vuex 可能是繁琐冗余的。确实是如此——如果您的应用够简单,您最好不要使用 Vuex。

    3)使用步骤

    (以vue2.x脚手架为例)

    3.1)下载安装:npm install vuex
    3.2)在src文件夹下--->创store--->index.js 这个文件就是vuex状态管理

    在文件中

    import Vue from 'vue'
    import Vuex from 'vuex'
    Vue.use(Vuex)
    const Store =new Vuex.Store({
    state:{},//数据存储
    mutations:{},//更改数据
    actions:{}//触发,调用更改数据
    getters:{//计算(类似computed)可以说是一个桥梁,不用直接访问state
    getState(state){returen state.msg}//这样访问这个就相当于访问state中的msg
    },
    muduld:{newmuduld//这里是模块名字}//模块,每个模块都拥有这五种方法和属性
    })
    export default Store
    

    在main.js引入

    import store from './store/index'//index可省略
    在vue实例中进行注册new Vue({//这里 store})
    

    在页.vue组件中使用

    获取样式:this.$store.state.count

    methods中用在
    this.$store.commit("cNum")

    //cNum----->mutations定义的函数---》修改state值 cNum(state){state.num++} 同步

    this.$store.dispatch("acNum")

    //acNum--->actions定义的函数---->函数在触发-》 mutations中定义函数 ---》修改state值 异步(同步不可以操作异步,异步可以操作同步的)

    getters在页面.vue的computed计算这里用
    computed:{getMsg(){renturn this.$store.getters.getState}}
    //这样调用getters中定义的定义

    Vuex辅助函数---》

    作用,就是使用更加的简洁(少敲代码,少掉点头发),使得在使用的.vue页面中访问storevuex页面更加的方便简介一点
    在那个.vue文件用,就在那里引用所要使用的 辅助函数

    使用:在.vue

    在没有引入vuex辅助函数的时候我们使用是
    this.$store.commit("cNum")---》同步

    this.$store.dispatch("acNum")异步

    this.$store.state.count---》获取变量

    this.$store.getters.getState---》计算变量
    在引入vuex函数后在访问就变成
    引用:import {mapGetters,mapMutations,mapState,mapAction} from 'vuex'
    扩展:
    其中mapMutations和mapAction
    在methods进行扩展出来...mapAction(["one","two"]/{"one":"o1","two":"t2"}) ,
    mapGetters和mapState
    在computed中进行扩展...mapState(['num']) ...mapGetters(['userInfo'])

    调用使用:
    this.two()--->mapMutations和mapAction
    this.num--->mapGetters和mapState


    以...mapGetters(["one","two"]/{"one":"o1","two":"t2"}) 为例详解:

    []/{}中写的是在store中定义好的方法名,所以调用的时候就不再使用this.$store.getters.one而是直接this.one就可以访问到数值了
    []和{} 数组和对象可以,但是数组要 名字一样,对象可以改名,可以不改名字


    Vuex模块化(优化)
    将实例里的参数,独立出一个模块,然后在引用的index.js
    state,
    mutations,
    actions,
    getters, 将以上四个独立模块,
    state.js---》let state ={}; export.default state //其余三个相同方法 (各个模块中若是用到彼此,在各个页面中可相互引用)
    在store文件夹---》index.js 引入 这四个模块


    axios调取接口存到state数据里
    在actions调用---》在mutations存值----》存到state
    注意:各模块中使用的别的模块的内容,要在模块中进行引用


    muduld详解和使用

    muduld模块,每个模块都拥有这五种方法和属性state,mutations,actions,getters,muduld
    上述中我们只是说有一仓库的时候的使用,
    muduld是在大仓库中放入的小仓库
    在主index文件中

    index的store文件.png

    创建引入的这user/order.js中的内容---每个模块可有可没有,但都支持


    user.png

    在小仓库user/order创建命名空间---使小仓库独立


    命名.png
    在页面.vue中的使用
    引入方式.png

    然后使用的方式就和上述中的使用方式一样,访问每个小仓库中的那样使用

    调用使用:
    this.two()--->mapMutations和mapAction
    this.num--->mapGetters和mapState


    不使用命名空间的使用------稍微带一嘴


    使用0.png

    相关文章

      网友评论

          本文标题:vuex的使用,vuex辅助函数、muduld的详解(文章下边)

          本文链接:https://www.haomeiwen.com/subject/eptfpktx.html