Vue2+Vue3基础入门到实战项目(六)——课程学习笔记

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第1张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第2张图片

镇贴!!!

day07

vuex的基本认知

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第3张图片

使用场景

  • 某个状态 在 很多个组件 来使用 (个人信息)

  • 多个组件 共同维护 一份数据 (购物车)

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第4张图片

构建多组件共享的数据环境

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第5张图片

1.创建项目

vue create vuex-demo

2.创建三个组件, 目录如下

|-components
|--Son1.vue
|--Son2.vue
|-App.vue

3.源代码如下

App.vue在入口组件中引入 Son1 和 Son2 这两个子组件






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






Son2.vue





创建一个空仓库

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第6张图片

创建仓库

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第7张图片

main.js导入挂载

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第8张图片

查看仓库

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第9张图片

核心概念 - state 状态

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第10张图片

如何提供&访问vuex的数据

提供数据

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第11张图片

访问数据

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第12张图片

实操:

提供数据

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第13张图片

访问数据

在App.vue中访问

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第14张图片

在main.js中访问

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第15张图片

通过辅助函数(简化访问)

自动映射

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第16张图片

1.导入mapState

import {mapState} from 'vuex'

2.数组方式引入state

mapState(['count'])得到的是红色框框住的对象

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第17张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第18张图片

一般使用展开运算符

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第19张图片

直接写成    {{属性名}}

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第20张图片

核心概念 - mutations(改变)

vuex遵循单向数据流

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第21张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第22张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第23张图片

检测需要成本

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第24张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第25张图片

再次点击按钮修改数据

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第26张图片

mutations的基本使用

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第27张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第28张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第29张图片

mutations传参

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第30张图片

mutation函数带参数

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第31张图片

页面中提交并携带参数

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第32张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第33张图片

减法练习

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第34张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第35张图片

提供mutation函数,页面中提交

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第36张图片

实时输入,实时更新

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第37张图片

注意此处不能使用v-model,因为要遵循单向数据流。

输入框内容渲染:(:value传入count,count已经经过辅助函数mapState简化访问)

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第38张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第39张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第40张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第41张图片

在方法里面调用:

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第42张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第43张图片

核心概念-actions

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第44张图片

提供action方法

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第45张图片

页面中dispatch调用

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第46张图片

辅助函数 - mapActions

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第47张图片

核心概念 - getters

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第48张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第49张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第50张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第51张图片

核心概念 - 模块 module (进阶语法)

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第52张图片

模块创建

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第53张图片

user.js

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第54张图片

setting.js

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第55张图片

导入到index.js

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第56张图片

在modules中使用

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第57张图片

数据已绑定

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第58张图片

模块中state的访问语法

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第59张图片

原生方式访问:

user模块

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第60张图片

setting模块

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第61张图片

通过mapState映射

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第62张图片

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第63张图片

开启命名空间

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第64张图片

再使用

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第65张图片

模块中getters的访问语法

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第66张图片

原生方式访问getters

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第67张图片

特殊的属性名:

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第68张图片

通过mapGetters辅助函数映射:

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第69张图片

使用映射:

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第70张图片

模块中mutation的调用语法

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第71张图片

方法一:

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第72张图片

提供mutation函数

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第73张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第74张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第75张图片

点击更新后

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第76张图片

分模块映射:

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第77张图片

使用映射

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第78张图片

模块中action的调用语法

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第79张图片

注册更新事件

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第80张图片

context是上下文,默认提交的就是自己模块的action和mutation

(前面说context理解为store,

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

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第81张图片

dispatch需要写明模块

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第82张图片

mapActions映射

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第83张图片

综合案例 - 购物车

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第84张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第85张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第86张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第87张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第88张图片

Vue2+Vue3基础入门到实战项目(六)——课程学习笔记_第89张图片

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

你可能感兴趣的:(Vue学习,学习,笔记,前端,javascript,vue.js)