zoukankan      html  css  js  c++  java
  • Vuex简单实例以及安装遇到的坑

    什么是Vuex?

    vuex是一个专门为vue.js设计的集中式状态管理架构。状态?我把它理解为在data中的属性需要共享给其他vue组件使用的部分,就叫做状态。简单的说就是data中需要共用的属性。

    vuex面试考点

    两张图一句话

    一句话:vuex中的异步操作只能在 actions中,也就是ajax交互请求数据

     

    引入Vuex(前提是已经用Vue脚手架工具构建好项目)

    1、利用npm包管理工具,进行安装 vuex。在控制命令行中输入下边的命令就可以了。

     npm install vuex --save

    2、新建一个store文件夹(这个不是必须的)并在文件夹下新建index.js文件,文件中引入我们的vue和vuex。

    import Vue from 'vue';
        import Vuex from 'vuex';

    3、使用我们vuex,引入之后用Vue.use进行引用。

    Vue.use(Vuex);

    通过这三步的操作,vuex就算引用成功了,接下来我们就可以尽情的玩耍了。

    定义 state mutations 并抛出

    const state = {
        cartCount: {
            cartNum: 0
        }
    }
    
    const mutations = {
        initCartCount(state, cartNum){
            state.cartCount = cartNum;
        }
    }
    
    export default new Vuex.Store({
        state,
        mutations
    });

    4、在main.js 中引入新建的vuex文件(全局引入vuex)

        import store from './store/index'

    5、再然后 , 在实例化 Vue对象时加入 store 对象 :

    /* eslint-disable no-new */
    new Vue({
        el: '#app',
        store,
        router,
        template: '<App/>',
        components: { App }
    })

    初出茅庐 来个Demo

      前端项目中,例如头部会有 用户名 和 购物车 数量,这两个属性,这两个属性也就是头部是在多个组件中引用的,同时,购物车数量有在多个地方发生改变,添加购物车,购物车数量加减,删除购物车等等

    1、在 vuex 中定义两个属性 一个 nickName 一个 cartCount。

    const store = new Vuex.Store({
        state: {
            nickName: '',
            cartCount: 0
        }
    });

    state 状态只能通过 mutations 改变,改变之后必须通过 commit 去提交改变要不然不会显示(也可以通过 action 提交,比如一步操作必须用这个提交)

    定义更新 用户名 这个mutations。同时定义,购物车数量改变的方法。

    const store = new Vuex.Store({
        state: {
            nickName: '',
            cartCount: 0
        },
        mutations: {
            updateUserInfor(state, nickName){
                state.nickName = nickName;
            },
            // 接收传过来的 数字 ,在现有的基础上 +=,加购物车就 传1,减就穿 -1,删除就传 (-当前商品的数量)。
            updateCartCount(state, cartCount){
                state.cartCount += cartCount;
            },
          // 购物车初始化,查看购物车的数量,上边那个是改变数量,这个只是查看不改变 initCartCount(state, cartCount){ state.cartCount
    = cartCount; } } });

    2、用export default 封装代码,让外部可以引用。

     export default new Vuex.Store({
            state
        });

    3、新建一个vue的模板,位置在components文件夹下,名字叫header.vue。在模板中我们引入我们刚建的store.js文件。

    vuex改变值是有一个时间的,有的时候我们的操作可能还没等vuex赋值完毕已经进行了。所以要用这个属性实时去监控。

     /**
        * vuex 通过这个计算属性 时时去变化 nickName,nickName在checklogin 的时候去赋值。
        */ 
        computed: {
            nickName(){
                return this.$store.state.nickName;
            },
            cartCount(){
                return this.$store.state.cartCount;
            }
        },

    页面中输出

    <li style="color: red" v-if="nickName">{{nickName}},欢迎回来</li>
    <span class="cartNum" v-if="nickName && (cartCount>0)">{{cartCount}}</span>

    在需要更改 vuex 的状态的地方

    例如:调用登录接口,成功之后 接口返回用户名

    this.$store.commit("updateUserInfor",res.body.result.userName);

    购物车顶部的图标旁边显示购物车数量,这个同样是在登录后调用查看购物车数量,不登录肯定不能知道购物车的数量的

    /**
            * 获取购物车数量赋值给 vuex
            */
            getCartCount(){
                this.$http.get('/users/getCartCount').then((res) => {
                    if(res.body.status == 0){
                        this.$store.commit("initCartCount",res.body.result);
                    }
                });
            }

    删除购物车(传递当前商品的数量)

    // 删除购物车时候,通知 vuex 更新数量
                        this.$store.commit("updateCartCount", -this.itemData.productNum);

    购物车点击加

    this.$store.commit("updateCartCount", 1);

    购物车点击减

    this.$store.commit("updateCartCount", -1);

    上边这种写法适用于,store比较小不需要单独建立store直接在main.js中写的情况。如果想单独建立以一个store文件的话:

    store => index.js

    import Vue from 'vue'
    import Vuex from 'vuex';
    
    Vue.use(Vuex)
    
    const state = {
        cartCount: {
            cartNum: 0
        }
    }
    
    const mutations = {
        initCartCount(state, cartNum){
            state.cartCount = cartNum;
        }
    }
    
    export default new Vuex.Store({
        state,
        mutations
    });

    main.js

    import store from './store/'
    
    new Vue({
        el: '#app',
        router,
        store,
        template: '<App/>',
        components: { App }
    })

    在需要调用的地方还是正常的上边的调用的方法

    vuex 计算属性简写:

    例如:在header 的组件中,用户名 和 购物车 数量都需要在这里计算,原本写法是

    computed: {
            nickName(){
                return this.$store.state.nickName;
            },
            cartCount(){
                return this.$store.state.cartCount;
            }
        },

    vuex 有一套简写的方法,在页面导入 mapState,在需要简写的地方导入

    import { mapState } from 'vuex'
    computed: {
            * mapState 数组里面 填写的参数,就是vuex 要返回的参数,也就是vuex要更新更改的数据
            * 它默认 执行 return this.$store.state.xxxx; xxxx就是数组中我们传入的
            */ 
            ...mapState(['nickName','cartCount'])
        },

    总结;vuex 相当于是把一个变量改为了全局,让我们在所有的地方都能访问到,不管在哪个最近修改了这个属性。

     

    下边讲下vuex安装所遇到的问题

    1.安装vux

    npm install vux --save-dev

    2.安装vux-loader

    npm install vux-loader --save-dev  //官网没提安装这个,但是不安装会报错

    3.安装less-loader以正确编译less源码

    npm install less less-loader --save-dev

    4.安装 yaml-loader 以正确进行语言文件读取

    npm install yaml-loader --save-dev

    5.修改build/webpack.base.conf.js中的代码

    将原文中的

    修改成如下的

    6.在安装完依赖和配置后文件以后,引入vux的模板

  • 相关阅读:
    Spring 实例化bean的三种方式
    Mybatis和Hibernate比较
    MyBatis学习总结(一)——MyBatis快速入门
    Java EE的十三个规范
    Python 测试代码覆盖率统计工具 coverage.py
    mysql explain执行计划详解
    Django模型的Field Types
    使程序在Linux下后台运行,程序运行前后台切换
    ubuntu中将本地文件上传到服务器
    Python-内置函数小结
  • 原文地址:https://www.cnblogs.com/haonanZhang/p/8404401.html
Copyright © 2011-2022 走看看