码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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的五个属性

  • 相关阅读:
    【OpenCV 例程200篇】229. 特征描述之 LBP 算子比较(skimage)
    Kubernetes 架构设计
    Java学习笔记(十六)
    Hive 删除一个字段
    嵌入式开发:如何调试Arm Cortex-M上的硬故障
    机密计算在国际市场高速发展,以可信执行环境为核心的机密计算成为隐私计算赋能领域主流的解决方案
    在真实环境中测试,如何及时停损
    从指针开始变强(四)之超级详细笔试题(二)
    ArrayList与List的层级关系及ArrayList解析
    计算机毕业设计之java+springboot基于vue的会员制医疗预约服务管理信息系统
  • 原文地址:https://blog.csdn.net/qq_46199553/article/details/125621524
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号