

镇贴!!!

使用场景
某个状态 在 很多个组件 来使用 (个人信息)
多个组件 共同维护 一份数据 (购物车)


vue create vuex-demo
- |-components
- |--Son1.vue
- |--Son2.vue
- |-App.vue
App.vue在入口组件中引入 Son1 和 Son2 这两个子组件
- <template>
- <div id="app">
- <h1>根组件h1>
- <input type="text">
- <Son1>Son1>
- <hr>
- <Son2>Son2>
- div>
- template>
-
- <script>
- import Son1 from './components/Son1.vue'
- import Son2 from './components/Son2.vue'
-
- export default {
- name: 'app',
- data: function () {
- return {
-
- }
- },
- components: {
- Son1,
- Son2
- }
- }
- script>
-
- <style>
- #app {
- width: 600px;
- margin: 20px auto;
- border: 3px solid #ccc;
- border-radius: 3px;
- padding: 10px;
- }
- style>
main.js
- import Vue from 'vue'
- import App from './App.vue'
-
- Vue.config.productionTip = false
-
- new Vue({
- render: h => h(App)
- }).$mount('#app')
Son1.vue
- <template>
- <div class="box">
- <h2>Son1 子组件h2>
- 从vuex中获取的值: <label>label>
- <br>
- <button>值 + 1button>
- div>
- template>
-
- <script>
- export default {
- name: 'Son1Com'
- }
- script>
-
- <style lang="css" scoped>
- .box{
- border: 3px solid #ccc;
- width: 400px;
- padding: 10px;
- margin: 20px;
- }
- h2 {
- margin-top: 10px;
- }
- style>
Son2.vue
- <template>
- <div class="box">
- <h2>Son2 子组件h2>
- 从vuex中获取的值:<label>label>
- <br />
- <button>值 - 1button>
- div>
- template>
-
- <script>
- export default {
- name: 'Son2Com'
- }
- script>
-
- <style lang="css" scoped>
- .box {
- border: 3px solid #ccc;
- width: 400px;
- padding: 10px;
- margin: 20px;
- }
- h2 {
- margin-top: 10px;
- }
- style>

创建仓库

main.js导入挂载

查看仓库


提供数据

访问数据

实操:
提供数据

访问数据
在App.vue中访问

在main.js中访问

自动映射

1.导入mapState
import {mapState} from 'vuex'
2.数组方式引入state
mapState(['count'])得到的是红色框框住的对象

可能有人想着直接赋值给computed,但这样的一个对象里面只有一个count方法

一般使用展开运算符

模板中就不需要写成 {{ $store.state.属性名}}

直接写成 {{属性名}}


错误写法检测会消耗性能,Vue默认不会对错误写法报错,如果希望报错,可通过开启严格模式

如图,错误代码并没有报错,也没有“正确”执行

检测需要成本

开启严格模式(上线时需要关闭,需要消耗性能)

再次点击按钮修改数据


在Store中通过mutations提供修改数据的方法

addCount加一、addFive加五、changeTitle改标题

mutations传参

mutation函数带参数

页面中提交并携带参数


减法练习

注册点击事件,并传入参数:

提供mutation函数,页面中提交

实时输入,实时更新

注意此处不能使用v-model,因为要遵循单向数据流。
输入框内容渲染:(:value传入count,count已经经过辅助函数mapState简化访问)





在方法里面调用:

甚至可以直接在页面中直接用


提供action方法

页面中dispatch调用








user.js

setting.js

导入到index.js

在modules中使用

数据已绑定


原生方式访问:
user模块

setting模块

通过mapState映射

映射后直接使用(报错):

开启命名空间

再使用


原生方式访问getters

特殊的属性名:

如何给对象添加特殊字符的属性名:

通过mapGetters辅助函数映射:

使用映射:


方法一:

提供mutation函数



点击更新后

分模块映射:

使用映射


注册更新事件

context是上下文,默认提交的就是自己模块的action和mutation
(前面说context理解为store,

需要如上访问,但此action处于模块中,不需要告知是user模块,更准确叫做上下文)

dispatch需要写明模块

mapActions映射








Vue2核心知识学习得差不多了。(达成一个小的阶段性胜利!)