zoukankan      html  css  js  c++  java
  • vueX

    1 Flux

    vuex是一个解决组件之间通信,实现组件之间共享数据的框架。

    参考了flux思想实现的框架。

    flux实现了单一数据源,数据单向流动等特征。

    flux包含了四个模块:

      action 消息对象

      dispatcher 捕获消息的

      store 存储数据的

      views 组件视图

    通信流程:

    一个组件发布了一个action对象。action被dispatcher捕获,根据消息类型处理数据。store会存储新的数据,并将新的数据传递给另一个组件。

    2 VueX

    vuex就是基于flux思想实现的框架,也实现了单一数据源,数据单向流动等特征。

    单一数据源:一个应用程序中,只能有一个store对象(用来存储数据的)

    数据单向流动:数据始终朝着一个方向传递(形成环路)。

    优势:应用中可能有很多环,但是彼此之间没有联系,所以在一个环中添加一个成员或者删除一个成员,只影响当前的环,不影响其它的环,因此可以将系统中的所有环抽象成一个环。

    vuex由三部分组成:

      action 消息对象

      state 用来存储数据的

      views 组件视图

    通信流程:

    一个组件发布了消息,消息被action捕获,并根据消息类型,处理数据

    数据改变了,存储在state中。

    state数据更新了,将新的数据传递给另一个组件。

    3 action 分类

    在vuex中,action共分两类:

      同步action:mutations :处理同步的消息对象(只能执行同步操作),可以被测试

      异步action: actions:处理异步的消息对象(可以执行异步操作),无法测试,所以为了测试,要再发布一个同步消息。

    注意:如果没有异步的操作,是可以直接发布同步action的(mutations)。

    4 store的组成

    在vuex中,要创建store对象(代表vuex部分)

    在一个应用程序中,只能有且只有一个store对象:store由以下几部分组成:

      state 用来存储静态数据的。store中的数据放在state中存储。

      getters 用来存储计算属性数据的。getters与state的区别与组件中data与computed区别是一样的。

      mutations 用来订阅同步消息的。用commit方法提交同步消息。

      actions 用来订阅异步消息的。用dispatch方法提交异步消息。

      mudules 用来切割store的

    规范:只能在mutations中修改state,不能在actions中修改state。

    5 使用vuex

    安装vuex:通过npm安装vuex模块,npm install vuex

    使用vuex大致分成五步:

    第一步:

      安装vuex:Vue.use(Vuex)。vue家族的插件,都可以使用Vue.use方法来安装。

      注意:在模块化开发中要安装(除了seajs),不使用模块化开发规范,不需要安装

    第二步:

      创建store对象,并传递各个组成部分。创建:new Store()

      组成部分:state, getters, mutations, actions, mudules ......

    第三步:

      在vue实例化对象中,通过store属性注册store实例化对象。

      注册目的:让所有的组件都可以获取$store对象。

    第四步:

      在一个组件中发布消息

    第五步:

      在一个组件中使用数据

    $store对象

    6 同步消息

    同步消息定义在mutations中,是一个对象:

      key 表示消息名称

      value 表示消息回调函数

        第一个参数表示state数据对象

        第二个参数表示commit方法提交的数据

          在方法中,用新的数据,更新state数据对象。

          commit方法:用来提交同步消息的方法

            第一个参数表示消息类型

            第二个参数表示提交的数据

          注意:数据只能在第二个参数中传递,想传递多个数据,可以放在数组或者对象中

    7 异步消息

    通过actions定义异步消息,是一个对象:

      key 表示消息名称

      value 表示消息回调函数

        第一个参数表示store对象

        第二个参数表示dispatch方法提交的数据

          在方法中,实现异步操作,但是不要修改state

          dispatch:用来提交异步消息的方法。

            第一个参数表示消息名称

            第二个参数表示提交的数据

          注意:数据只能在第二个参数中传递,想传递多个数据,可以放在数组或者对象中。

    8 严格模式

    vuex的规范:只能在mutations修改state数据,不能在其它的位置修改state数据。

    vuex为了严格限制这一规范,提供了严格模式:

      在store实例化对象中,设置strict: true

    这样当我们在其它位置修改state数据的时候,就会抛出警告错误。

    9 getters

    store中存储的计算属性数据,可以对state中的数据动态处理;

    是一个对象

      key 表示数据名称

      value 计算的方法

        第一个参数表示当前的state数据

        第二个参数表示当前的getters数据

      必须有返回值,表示计算的结果。

    10 mapState

    vue中还有mapGetters, mapMutations, mapActions,都是做映射的

    对state数据做处理,并返回映射的结果

    参数是对象

      key 结果对象的属性名称

      value 结果对象的属性值

        可以是字符串:与state中的数据名称对应

        可以是函数:对state做处理并返回新结果。

          第一个参数是state

          第二个参数是getters

    解决了访问数据的时候,每次都要写this.$store的重复书写问题。简化了对state数据的访问。

     

    如果直接给computed赋值mapState对象,那么computed中就无法定义其他的属性数据

    所有为了可以继续定义计算属性数据,可以使用...语法,将mapState对象复制给computed

    11 模块切割

    在一个非常复杂的应用中,共享的数据会有很多,所有的数据都直接写在state中,就可能会产生命名空间冲突的问题,

    为了解决冲突问题,vue提供了modules属,允许对模块切割。

    属性值是一个对象:

      key表示命名空间

      value表示该命名空间对应的子store对象

    在store中,数据作为state来存储的,因此切割store的本质就是切割state,因此切割后,只有state需要携带命名空间,其它的的数据正常访问。

    切割的子store对象理论上也是store对象,因此可以设置store中的所有组成部分:mutations, actions, state, getters, modules等。

    切割后,各个部分如果重名的影响:

      1 state:由于具有命名空间,因此不受影响。

      2 getters: 各个store之间的getters数据不允许同名。所有的getters都添加在全局。

      3 actions和mutations:可以正常访问:全局的消息修改全局的数据,局部的消息修改局部的数据。

    12 插件

    为了测试vuex,vuex提供了测试插件:vuex/dist/logger.js

    该插件可以帮助我们测试同步消息(mutations),不能测试异步消息(actions)

    是一个方法,执行后才能被使用。

    使用插件:在store对象中的plugins中定义插件。

    使用插件的目的:为了复用插件对store拓展的功能。

     -----------------------------------------------------------------------------------------

    当我们使用store中数据时,页面就可以捕获到每次同步的消息,方便测试vuex

    subscribe:

    store对象提供了subscribe方法,可以监听store的变化。

    参数是回调函数,表示当发布同步消息的时候,执行的方法

      第一个参数表示消息对象:消息类型,传递的数据,

      第二个参数表示state对象。

    根据state数据来判断执行的结果是否符合预期。

    只能监听同步消息,无法监听异步消息。

    自定义插件

    自定义插件就是将对store的拓展封装起来,在不同的项目中复用。

    插件是一个方法,参数是store对象。

    在方法中,对store拓展

    13 state代理

    在表单中,想对state中的数据实现数据双向绑定,可以使用state代理技术。

    由于不能在store的外部修改state,因此要通过计算属性数据代理state;

    为计算属性数据定义特性对象:

      在取值器方法中,获取state数据

      在赋值器方法中,修改state数据

    例如:

    ----------------------------------------------------------------------------------------------------------------------

  • 相关阅读:
    POI处理Excel工具类
    Mac打开隐藏文件夹
    markdown语法
    U盘分区合并
    数组
    Java插入到mysql数据库显示问号?
    使用vmware打开别人提供好的vmx没反应怎么办?
    求长方形的外接圆
    读取mysql数据库
    excel对列的常用操作
  • 原文地址:https://www.cnblogs.com/yess/p/14815361.html
Copyright © 2011-2022 走看看