Vue 开发实战
唐金州
一点资讯前端技术专家,Ant Design Vue 作者
60939 人已学习
新⼈⾸单¥59
课程目录
已完结/共 53 讲
Vue 开发实战
登录|注册
留言
23
收藏
沉浸
阅读
分享
手机端
回顶部
当前播放: 19 | 如何在Vue中使用Vuex
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.75x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
01 | 课程介绍
02 | Vue简介
03 | 内容综述
05 | 组件基础及组件注册
04 | 第一个Vue程序
06 | Vue组件的核心概念:事件
07 | Vue组件的核心概:插槽
08 | 理解单文件组件
09 | 双向绑定和单向数据流不冲突
10 | 理解虚拟DOM及key属性的作用
11 | 如何触发组件的更新
12 | 合理应用计算属性和侦听器
13 | 生命周期的应用场景和函数式组件
14 | 指令的本质是什么
15 | 常用高级特性provide/inject
16 | 如何优雅地获取跨层级组件实例(拒绝递归)
17 | template和JSX的对比以及它们的本质
18 | 为什么需要Vuex
19 | 如何在Vue中使用Vuex
20 | Vuex核心概念及底层原理
21 | Vuex最佳实践
22 | Vue Router的使用场景
23 | 选择何种模式的路由及底层原理
24 | Nuxt解决了哪些问题?
25 | Nuxt核心原理是什么?
26 | UI组件库对比:Element UI、Ant Design Vue、iView
27 | 提升开发效率和体验的常用工具:ESLint、Prettier、vue-devtools
28 | 单元测试的重要性及其使用
29 | 生态篇习题解答(上)
30 | 生态篇习题解答(下)
31 | Ant Design Pro介绍
32 | 使用Vue CLI 3快速创建项目
33 | 如何自定义Webpack和Babel配置
34 | 如何设计一个高扩展性的路由
35 | 实现一个可动态改变的页面布局
36 | 如何将菜单和路由结合
37 | 如何使用路由管理用户权限
38 | 更加精细化的权限设计(权限组件、权限指令)
39 | 如何在组件中使用ECharts、Antv等其他第三方库
40 | 如何高效地使用Mock数据进行开发
41 | 如何与服务端进行交互(Axios)
42 | 创建一个普通表单
43 | 初始数据、自动校验、动态赋值
44 | 创建一个分步表单
45 | 自己封装一个支持自动校验的表单项
46 | 如何管理系统中使用的图标
47 | 如何定制主题及动态切换主题
48 | 如何做好国际化
49 | 如何高效地构建打包发布
50 | 如何构建可交互的组件文档
51 | 如何做好组件的单元测试
52 | 如何发布组件到npm
53 | 结课测试&GitHub相关生态应用(持续集成、单测覆盖率、文档发布、issue管理)
本节摘要

勘误

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

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

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

源代码及课件地址

https://gitee.com/geektime-geekbang/geektime-vue-1

登录 后留言

全部留言(23)

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

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

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

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

2019-03-28
3
@
希望老师能稍微更新快点,我十分感兴趣后面的实战项目。

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

2019-03-27
2
小霞
为什么const 变量名 = new Vuex.Store({}); 用 this.$变量名 就不能拿到定义的数据,但是如果变量名是store就可以呢?

作者回复: 这和你起的名字没关系 是vuex内部做的 不必纠结这个

2020-04-20
1
qf年间
老师请问为什么要在computed里面获取count值呢,这个是否跟生命周期有关

作者回复: 无关,放在计算属性里面可以很好的响应vuex中数据的变化

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

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

2019-03-28
2
1
刘彪
启动演示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-27
1
qf年间
有没有什么避免每次都清理缓存刷新页面的方法啊,要不有的时候总抱错

作者回复: 清理缓存? 你说的是热更新吧? 如果是热更新,没有办法,但也不是每次都需要啊,大部分的改动都可以完美支持的

2019-12-19
Ted
请问下老师使用的命令行工具叫什么?

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

2019-04-02
virtual
$store是通过new Vue.use(Vuex)的时候注入挂载到实例this上面的。在注入的时候通过Vue.mixin(),在生命周期为beforecreate的时候完成的
2020-05-19
21
收起评论