下载APP
登录
关闭
讲堂
算法训练营
企业服务
热点资讯
极客商城
客户端下载
兑换中心
渠道合作
推荐作者
当前播放: 21 | 如何在Vue中使用Vuex
00:00 / 00:00
标清
  • 标清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
00:00
付费课程,可试看

Vue开发实战

共50讲 · 50课时,约500分钟
9669
免费
01 | 课程介绍
免费
02 | Vue简介
免费
03 | 内容综述
免费
04 | 第一个Vue程序
免费
05 | 初识单文件组件
免费
06 | Vue组件的核心概念:属性
免费
07 | Vue组件的核心概念:事件
08 | Vue组件的核心概念:插槽
09 | 双向绑定和单向数据流不冲...
10 | 理解虚拟DOM及key属性的...
11 | 如何触发组件的更新
12 | 合理应用计算属性和侦听器
13 | 生命周期的应用场景和函数...
14 | 指令的本质是什么
15 | 常用高级特性provide/inj...
16 | 如何优雅地获取跨层级组件...
17 | template和JSX的对比以及...
18 | 基础篇习题解答(上)
19 | 基础篇习题解答(下)
20 | 为什么需要Vuex
21 | 如何在Vue中使用Vuex
22 | Vuex核心概念及底层原理
23 | Vuex最佳实践
24 | Vue Router的使用场景
25 | 选择何种模式的路由及底层...
26 | Nuxt解决了哪些问题?
27 | Nuxt核心原理是什么?
28 | UI组件库对比:Element U...
29 | 提升开发效率和体验的常用...
30 | 单元测试的重要性及其使用
31 | 生态篇习题解答(上)
32 | 生态篇习题解答(下)
33 | Ant Design Pro介绍
34 | 使用Vue CLI 3快速创建...
35 | 如何自定义Webpack和Babel...
36 | 如何设计一个高扩展性的路...
37 | 实现一个可动态改变的页面...
38 | 如何将菜单和路由结合
39 | 如何使用路由管理用户权限
40 | 更加精细化的权限设计(权...
41 | 如何在组件中使用ECharts...
42 | 如何高效地使用Mock数据进...
43 | 如何与服务端进行交互(Ax...
44 | 创建一个普通表单
45 | 初始数据、自动校验、动态...
46 | 创建一个分步表单
47 | 自己封装一个支持自动校验...
48 | 如何管理系统中使用的图标
49 | 如何定制主题及动态切换主...
50 | 如何做好国际化
51 | 如何高效地构建打包发布
52 | 如何构建可交互的组件文档
53 | 如何做好组件的单元测试
54 | 如何发布组件到npm
55 | GitHub相关生态应用(持续...
本节摘要

勘误

Vuex 的 actions 应该避免直接操作 state,state 的更改应该由 mutations 去修改,不然 vue-devtools 插件记录不到 state 变更,
actions 可以根据当前 state 进一步处理数据,计算或请求后端接口,然后通过 commit 的形式提交给 mutations 去处理。

本节计数器 actions 部分直接操作了 state ,这个写法有问题,正确代码如下:

increment({commit}) {
  setTimeout(()=>{
    commit('increment')
  }, 3000)
}
复制代码

源代码地址

https://github.com/geektime-geekbang/geektime-vue-1/tree/master/vuex-demo1

https://github.com/geektime-geekbang/geektime-vue-1/tree/master/vuex-demo2

https://github.com/geektime-geekbang/geektime-vue-1/tree/master/vuex-demo3

展开

精选留言(10)

  • Yrt 置顶
    2019-03-27
    有个问题, 为什么在actions 里的increment函数可以直接修改 state.count? 我翻了文档,里面说的是在actions里去提交mutations 不让直接更改状态 。increment 文档里的传的参数是context 然后视频里传的 是state 是因为这个参数的原因吗?

    作者回复: 感谢提醒,的确不应该在actions里面去操作state,这样devtools就记录不到变化状态了,传的依然是context哈,注意state两边的大括号,他的作用就是从context里面取出来 state,也是es6的语法,正确代码应该是:
    actions: {
        increment({commit}) {
          setTimeout(()=>{
            commit('increment')
          }, 3000)
        }
      },

    5
  • NullPointerException
    2019-03-26
    Vue 已经用了挺久了,在公司也用 Vue 写过了几个项目,虽然是个Java程序员 但对前端越来越感兴趣。 希望在这门课学习之后可以对 Vue 的基础有更深入的理解。
    3
  • @
    2019-03-27
    希望老师能稍微更新快点,我十分感兴趣后面的实战项目。

    编辑回复: 下周开始更新实战部分

    2
  • Man
    2019-08-25
    vuex是否可以结合saga一起使用?将异步请求或者业务逻辑独立出来?
  • 烟雨海花lwl
    2019-04-15
    真的和mobx很像,打开了我vue从无到入门的启蒙之路,打卡
  • Ted
    2019-04-02
    请问下老师使用的命令行工具叫什么?

    作者回复: 就是使用系统自带的,mac  terminal,如果你也使用的mac,看到的和我不一样,是我自己自定义了主题。

  • 药岩
    2019-03-28
    老师,我想问下,使用vuex的时候有没有必要将所有的state都转化成getter,然后让组件通过mapGetters去获取属性

    作者回复: 没必要的,单个状态没有任何意义,涉及到进一步计算合并才使用getter

  • 王永林
    2019-03-28
    感觉不懂node开发学习起来有点吃力,最近搞了好多遍环境,总是因为版本依赖问题最后导致无法运行起来,于是又重新建项目。作为老java开发,也只会在idea下写代码,就是开发用的插件不支持2.6

    作者回复: 不应该,版本依赖并不需要自己配置,这也是相对于java的优势,你完全可以不懂node,就可以使用vue

  • 刘彪
    2019-03-27
    启动演示DEMO源码出现依赖错误,但是已经安装过core-js了
    These dependencies were not found:

    * core-js/modules/es6.array.find-index in ./node_modules/_cache-loader@2.0.1@cache-loader/dist/cjs.js??ref--12-0!./node_modules/_babel-loader@8.0.5@babel-loader/lib!./node_modules/_cache-loader@2.0.1@
    展开

    作者回复: 重装试试吧 npm建议使用 taobao 源。

  • 初雨初霁
    2019-03-26
    我现在的项目一直在使用VUE,之前对vuex只停留在会使用得基础上,看完之后觉得对原理有了更进一步的认识。后面我也会抽时间看看源代码,希望更进一步对vuex进行深入得了解
限时拼团立省 ¥40查看拼团规则
单独订阅¥129
2人成团¥89