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


    镇贴!!!

    day07

    vuex的基本认知

    使用场景

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

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

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

    1.创建项目

    vue create vuex-demo

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

    1. |-components
    2. |--Son1.vue
    3. |--Son2.vue
    4. |-App.vue

    3.源代码如下

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

    1. <template>
    2. <div id="app">
    3. <h1>根组件h1>
    4. <input type="text">
    5. <Son1>Son1>
    6. <hr>
    7. <Son2>Son2>
    8. div>
    9. template>
    10. <script>
    11. import Son1 from './components/Son1.vue'
    12. import Son2 from './components/Son2.vue'
    13. export default {
    14. name: 'app',
    15. data: function () {
    16. return {
    17. }
    18. },
    19. components: {
    20. Son1,
    21. Son2
    22. }
    23. }
    24. script>
    25. <style>
    26. #app {
    27. width: 600px;
    28. margin: 20px auto;
    29. border: 3px solid #ccc;
    30. border-radius: 3px;
    31. padding: 10px;
    32. }
    33. style>

    main.js

    1. import Vue from 'vue'
    2. import App from './App.vue'
    3. Vue.config.productionTip = false
    4. new Vue({
    5. render: h => h(App)
    6. }).$mount('#app')

    Son1.vue

    1. <template>
    2. <div class="box">
    3. <h2>Son1 子组件h2>
    4. 从vuex中获取的值: <label>label>
    5. <br>
    6. <button>值 + 1button>
    7. div>
    8. template>
    9. <script>
    10. export default {
    11. name: 'Son1Com'
    12. }
    13. script>
    14. <style lang="css" scoped>
    15. .box{
    16. border: 3px solid #ccc;
    17. width: 400px;
    18. padding: 10px;
    19. margin: 20px;
    20. }
    21. h2 {
    22. margin-top: 10px;
    23. }
    24. style>

    Son2.vue

    1. <template>
    2. <div class="box">
    3. <h2>Son2 子组件h2>
    4. 从vuex中获取的值:<label>label>
    5. <br />
    6. <button>值 - 1button>
    7. div>
    8. template>
    9. <script>
    10. export default {
    11. name: 'Son2Com'
    12. }
    13. script>
    14. <style lang="css" scoped>
    15. .box {
    16. border: 3px solid #ccc;
    17. width: 400px;
    18. padding: 10px;
    19. margin: 20px;
    20. }
    21. h2 {
    22. margin-top: 10px;
    23. }
    24. style>

    创建一个空仓库

    创建仓库

    main.js导入挂载

    查看仓库

    核心概念 - state 状态

    如何提供&访问vuex的数据

    提供数据

    访问数据

    实操:

    提供数据

    访问数据

    在App.vue中访问

    在main.js中访问

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

    自动映射

    1.导入mapState

    import {mapState} from 'vuex'

    2.数组方式引入state

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

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

    一般使用展开运算符

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

    直接写成    {{属性名}}

    核心概念 - mutations(改变)

    vuex遵循单向数据流

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

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

    检测需要成本

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

    再次点击按钮修改数据

    mutations的基本使用

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

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

    mutations传参

    mutation函数带参数

    页面中提交并携带参数

    减法练习

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

    提供mutation函数,页面中提交

    实时输入,实时更新

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

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

    在方法里面调用:

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

    核心概念-actions

    提供action方法

    页面中dispatch调用

    辅助函数 - mapActions

    核心概念 - getters

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

    模块创建

    user.js

    setting.js

    导入到index.js

    在modules中使用

    数据已绑定

    模块中state的访问语法

    原生方式访问:

    user模块

    setting模块

    通过mapState映射

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

    开启命名空间

    再使用

    模块中getters的访问语法

    原生方式访问getters

    特殊的属性名:

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

    通过mapGetters辅助函数映射:

    使用映射:

    模块中mutation的调用语法

    方法一:

    提供mutation函数

    点击更新后

    分模块映射:

    使用映射

    模块中action的调用语法

    注册更新事件

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

    (前面说context理解为store,

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

    dispatch需要写明模块

    mapActions映射

    综合案例 - 购物车

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

  • 相关阅读:
    操作系统(2)进程管理(上)进程与线程
    甘特图组件DHTMLX Gantt用例 - 如何自定义任务、月标记和网格新外观
    HTB-Antique
    IDA反汇编之栈帧例释
    Chainlink Keepers 能够帮助 Web3 开发者更快开发的 7 个特性
    【状态估计】将Transformer和LSTM与EM算法结合到卡尔曼滤波器中,用于状态估计(Python代码实现)
    U231683 younger 永存
    Vue3+TS中的shims-vue.d.ts文件的作用及代码说明
    QT 事件与信号区别
    【Kotlin 协程】协程的挂起和恢复 ① ( 协程的挂起和恢复概念 | 协程的 suspend 挂起函数 )
  • 原文地址:https://blog.csdn.net/upgrade_bro/article/details/132592540