zoukankan      html  css  js  c++  java
  • Vuex简介

    1. Vuex简介

      官方解释:

        1. Vuex是一个专门为Vue.js应用程序开发的状态管理模式

        2. Vuex采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可以测的发生发生改变

        3. Vuex页集成到Vue的官方调试工具devtools extension,提供了诸如零配件的time-travel调试,状态快照导入导出等高级调试功能

      状态管理到底是什么

        1. 可以将其看作把需要多个组件共享的变量全部存储在一个对象里里面

        2. 将这个对象放在顶层的Vue实例中,让其他组件可以使用

        3. 这样的话,所有组件都可以来共享这个对象中的所有属性了

      什么时候需要用到多组件共享同一种状态呢

        1. 在大型开发中,会遇到多个界面间的共享

        2. 如登陆状态,用户名,头像,位置

        3. 在多个页面中加入购物车,最后要进行汇总

    2. 创建一个store仓库并向其内部添加变量

                        1. 安装Vuex

                            终端运行指令:npm install vuex --save

                        2. 新建一个store仓库文件夹,在其中新建一个index.js(用法类似于路由router)

                        3. 在index.js文件中引用Vuex插件

                            import Vue from 'vue'
    
                            import Vuex from 'vuex'
    
                            // 1. 使用插件
    
                            Vue.use(Vuex);
    
                            // 2. 创建对象
    
                            const store = new Vuex.Store({
    
                                state:{
    
                                    counter: 1000,
    
                                },
    
                                mutations:{},
    
                                actions:{},
    
                                getters:{},
    
                                modules:{},
    
                            })
    
                            // 3. 导出对象
    
                            export default store
    View Code

          4. 在入口文件main.js中,引入store插件并挂载到主组件上

                            import store from './store'
    
                            new Vue({
    
                                el: '#app',
    
                                store,
    
                                render: h => h(App)
    
                            })
    View Code

    3. devtools安装

        仓库中的变量我们可以通过调用的形式任意修改,但是这无法追踪是哪个页面修改的,因此

      安装步骤:

        1. Chrome浏览器 -> 扩展程序 -> 搜索:devtools -> 添加Vue.js.devtools

        2. 检查:Chrome浏览器中的开发者模式下,可以找到Vue栏目即表示图哦站程序安装成功

    4. store中的参数修改和devtools的应用

      1. 在store中的到处对象中的mutations中添加方法

                            mutations:{
    
                                increment(state){
    
                                    state.counter++;
    
                                },
    
                                decrement(state){
    
                                    state.counter--;
    
                                },
    
                            },
    View Code

      2. 在各个修改仓库参数的页面中,发送请求,通过启动mutations中的方法实现变量修改

                                // 在相应地方调用方法
    
                                <button @click="add()">增加</button>
    
                                // 在相应方法中发送修改变量的请求
    
                                methods: {
    
                                    add(){
    
                                    this.$store.commit('increment');
    
                                    },
    
                                    minus(){
    
                                    this.$store.commit('decrement');
    
                                    },
    
                                }
    View Code

    5. Vuex中的核心概念

      Vuex导出对象中,包含几个元素,这些元素都是对象

  • 相关阅读:
    忘记mysql的登陆密码该怎么办?
    localhost和127.0.0.1的区别
    什么是DAPP
    System.NullReferenceException:未将对象引用设置到对象的实例,这是一个新鸟,中鸟,老鸟都避不开的错误
    VS2015中常用快捷键的修改推荐
    Win10系统开启IIS服务步骤
    ASP.NET学习路线图
    我眼中的技术地图
    WEBSTORM中html文件运行之后出现乱码的问题解决
    ExtJS新手学习中常见问题
  • 原文地址:https://www.cnblogs.com/carreyBlog/p/13672721.html
Copyright © 2011-2022 走看看