zoukankan      html  css  js  c++  java
  • vue使用--vuex快速学习与使用

     

      什么是vuex?

      Vuex核心概念

      Vuex安装与使用

        1.安装

        2.目录结构与vuex引入

        3.store中变量的定义、管理、派生(getter)

        4.vuex辅助函数的使用说明

      Vuex刷新数据丢失问题处理

              

     什么是vuex?

    Vuex 是专门为 Vue.js 设计的状态管理库,采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

    简单地说就是采用全局单例模式,将组件的共享状态抽离出来管理,使组件树中的每一个位置都可以获取共享的状态(变量)或者触发行为。

    额,或者更直白的说就是响应式的全局变量

    vuex核心概念

    State 共享状态(即变量)
    Getter 基于state的派生状态,可理解为组件中的计算属性
    Mutation 更改vuex的store中状态的唯一方法,通过提交mutation修改状态,同步操作(规则上是不允许异步操作的,虽然异步也可以执行,但是对devtool调试的状态跟踪或多个状态更改操作相互依赖是很不好的,所以不要觉得只要不报错我就可以这么用,还是尽量按照规则来比较好)
    Action 类似mutation,不同之处,1.通过提交mutation修改状态   2.支持异步操作
    Module 模块,在大型项目中为了方便状态的管理和协作开发将store拆分为多个子模块(modules),每个子模块拥有完整的state、mutation、action、getter

    vuex安装与使用

    1.安装vuex(命令)

    npm install vuex --save     // 如果安装了淘宝镜像,可以使用 cnpm安装

    2.新建store.js ( 名字随便起 ),引入vue和vuex,结构如下

    在根实例中注册store

    3.store中变量的定义、管理、派生(getter)

     ①state--状态  

     我们在state中定义属性name,给一个初始值 “张三”;在store实例中注册state;在组件中使用$store.state.name使用定义的属性name

      

    运行程序,在页面上显示出了我们定义的name属性,这里我们使用的是this.$store.state来访问vuex中定义的变量,还有一种辅助函数mapState的方式,我们在后边再讲解。好了,我们继续,定义了状态,我们就要对状态进行管理,去更改状态的值,就是下面要说的mutation

     ②mutation--更改store中状态的唯一方法

     之所以说唯一,是因为vuex中规定只能通过提交mutation的方式去更改store中的状态,包括action中的操作,也是通过提交mutation去修改。

     另外一点就是vuex中规定mutation中不能包含异步操作,这个在上面的核心对象中已有简单介绍。

     继续我们的操作,直接上代码:

      

                                                  (store.js)                                                                                                          (示例组件)

     效果如下:

     在store.js的mutations中我们定义了两个方法,一个是不带参数更新name,一个是带参数更新name。

     在示例组件的methods中,我们定义了两个方法,一个是调用无参的mutation方法,一个是调用带参的mutation方法(包含两种方式【载荷】、【对象】)

     总结如下:

     ✦.mutation下事件的调用是通过 this.$store.commit 传入对应的type调用,关于辅助函数 mapMutations 的使用在后面一期讲解

     ✦.mutation下事件的定义分为无参的和有参的两种形式

     ✦.mutation事件的调用有两种形式,载荷和对象

     ③anction--异步更改状态

     上面在mutation的介绍中我们提到了,mutation中规则上是不允许异步操作的,那如果我们需要异步的进行更改状态怎么办?于是vuex为我们提供了action。

     先上代码:

     

                                                  (store.js)                                                                                                          (示例组件)

     效果:

     

     从代码和效果中,我们能很直观得到两条信息:

      1.action 与 mutation 除了使用了异步操作和调用mutation,其它使用并无差别  

      2.异步操作时,可以明显的看到我们设置的信息在延迟1s后发生改变

     总结如下:

     ✦.action中不能直接更改状态,它是通过提交mutation来实现操作

     ✦.它的参数是一个与 store 实例具有相同方法和属性的 context 对象,所以可以通过context.state来获取store中的状态,可以通过context.commit来提交更改等

     ✦.action的调用使用 $.store.dispatch

     ✦.action事件的定义分为有参和无参两种

     ✦.action事件的触发同样可以使用载荷和对象两种方式

    ④getter--store中state的派生状态

     getter,我们可以理解为是对store中state的一些派生状态,也可以理解为一种计算属性,因为它像计算属性一样,返回值会根据它的依赖被缓存起来,且依赖对象发生改变的时候它才会被重新计算。

     getter的使用对我来讲就是将对store中某个属性相同的处理操作抽出出来,做了一个公共的处理

     例如,我们使用store中name的时候,需要做一个判断:如果是张三,返回“张三最棒”,其它的原样返回,我们可以这样做

     

     页面上将 this.$store.state.name 改为 formatterName即可。但是,如果我们这个操作不只这一个组件使用,那我们就需要在每一个组件中去定义这样一个计算属性,且不说代码冗余的问题,后期如果要更新后缀,想想吧,挨着一个一个组件的去巴拉。。。

     而使用getter则可以很好的解决这个问题,不仅代码简洁,也利于维护,不多说,上getter使用代码:

      

                                             (store)                                                                                                                        (示例组件)

    效果:

     总结如下:

     ✦.getter类似计算属性,是对store中state的一些派生状态,可以简化代码、便于维护

     ✦.getter的使用方法 $.store.getters.属性名

     ✦.getter的定义可以带参可以不带参

    关于module,它是对store的一个分割,将store分割成一个个小的模块,每个模块中又具有store完整的功能。他的使用主要面向一些状态非常多的大型应用,关于module的使用在这就不讲了,有兴趣可以看一下官网的介绍和讲解,穿梭>>>

     4.vuex辅助函数的使用说明:

      vuex的辅助函数有:mapStatemapMutationsmapGettersmapActions

      它们的使用我们可以配合ES6的展开运算符将其与局部计算属性或方法混合使用。使用辅助函数后我们对state、mutation、getter、actiopn的使用可以改成以下这样:

        

        (State  =>  mapState)

        

        (mutation  =>  mapMutations)

       

        (action   =>    mapActions)

       

       (getter   =>    mapGetters)

     vuex的刷新页面丢失问题处理

      有些小伙伴可能发现了,vuex在页面刷新后,store中的状态将被重新初始化,赋值的数据丢失,针对这个问题怎么处理呢? ---我们可以这样处理,在页面刷新或离开之前将store中的数据保存到sessionStorage 或 localStorage中,在页面重新加载后再将数据取出,通过vuex的$store.replaceState 将数据替换到store中,上代码

      app.vue:

    复制代码
     1 created () {
     2     var store = require('store');
     3 
     4     //在页面加载时读取sessionStorage里的状态信息
     5     if (sessionStorage.getItem("storedata") ) {
     6         this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(sessionStorage.getItem("storedata"))))
     7     }
     8     //在页面刷新时将vuex里的信息保存到sessionStorage里
     9     window.addEventListener("beforeunload",()=>{
    10         sessionStorage.setItem("storedata",JSON.stringify(this.$store.state))
    11     });
    12     // 兼容iphone手机
    13     window.addEventListener("pagehide",()=>{
    14         sessionStorage.setItem("storedata",JSON.stringify(this.$store.state))
    15     });
    16   },
    复制代码

      好了,写到这里吧~~,不足之处欢迎指出,好的建议感谢提出,谢过!

  • 相关阅读:
    窗体句柄总是0
    该函数设置由不同线程产生的窗口的显示状态。
    zip压缩解压缩 项目icsharpcode-SharpZipLib-e012155
    VS(Microsoft Visual Studio2010)工具打开项目所需的应用程序,出现未安装(.csproj)的应用程序的解决办法
    Cocoa深入学习:NSOperationQueue、NSRunLoop和线程安全
    iPhone 6出现后,如何将一份设计稿支持多个尺寸?
    iPhone/Mac Objective-C内存管理教程和原理剖析
    What does the “__block” keyword mean?
    UIView frame, bounds and center
    ARC __bridge modifiers demystified
  • 原文地址:https://www.cnblogs.com/onesea/p/13160786.html
Copyright © 2011-2022 走看看