• vuex的使用


    computed的响应式依赖(缓存)

    1. computed的每一个计算属性都会被缓存起来,只要计算属性所依赖的属性发生变化,计算属性就会重新执行,视图也会更新。下面代码中,计算属性fullName,它依赖了firstName和lastName这两个属性,只要它们其中一个属性变化,fullName就会重新执行。
      2.computed计算属性会被缓存,在下面代码中使用了两次fullName,但在控制台只输出了一次 “这是fullName”。

    mapState作用:可以辅助获得多个state的值

    vuex中state中的数据在使用的时候,一般都是在computed中定义的,以为在data中定义的话是一次性的,不会随着vuex中数据变化而变化,虽然可以通过watch监听,但是很麻烦,如下:

    //在计算属性中
    computed:{
    	...mapState([
    		//必须带引号
    		'menuStatus'
    	])
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    computed: {
        ...mapState({
          userInfo: state => state.user.userInfo,
          avatar: state => state.user.avatar
        }),
        ...mapGetters([
          'company'
        ])
    
      },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    mapGetters

    引入

       import { mapGetters  } from "vuex";
    
    
    • 1
    • 2

    如果一个变量或对象需要在多个页面和组件中使用,那么,可以使用mapGetters。

    computed: {
                   ...mapGetters(["freeShipping"])
              } ,
    
    • 1
    • 2
    • 3
      computed: mapGetters(["userInfo","freeShipping"]),
    
    • 1

    3,页面变量取用

    {{freeShipping.value}}
    
    • 1
    //state的作用是存储公共数据
    //state是响应式的,如果修改了属性,那么在相对应,组件视图上的值也会改变
    //在store里定义格式
    new Vuex.store({
      state: {
       属性名: 属性值 
      }
    })
    
    //在组件中使用格式
    this.$store.state.属性名
    
    //在模板中可省略this
    {{$store.state.属性名}}
    
    //在组件中使用map辅助函数:
    computed: { 
      ...mapState(['属性名']), 
      ...mapState({'新名字': '属性名'})
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    Vuex- Action的 { commit }

    没有解构的

    actions: {
        increment (context) {
          context.commit('increment')
        }
      }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    ES2015参数解构 (opens new window)的简化代码

    actions: {
      increment ({ commit }) {
        commit('increment')
      }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    在vue组件中get
    
    import { mapGetters } from 'vuex'
    export default {
    computed: {
    ...mapGetters(['number']),
    }mounted () {
    this.$store.dispatch('setNumber',10).then(() => {
    console.log(this.number)
    })
    }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    action的用法
    action的用法
    vuex的五个属性

  • 相关阅读:
    Java学习路线(13)——Collection集合类:List集合与Set集合
    环形链表(LeetCode 141、142)
    Centos8安装CDH解决不兼容问题
    App Languages 批量导入管理flutter多语言文案
    Shell 函数详解(函数定义、函数调用)
    基于nodejs+vue 校园通勤车系统
    Filebeat+Kafka+ELK日志分析架构
    MATLAB平台学习(13)一些感悟
    某手创作服务 __NS_sig3 sig3 | js 逆向
    我从未结束的Java之旅(二)
  • 原文地址:https://blog.csdn.net/qq_46199553/article/details/125621524