购物车案例--分模块存储数据,发送请求数据渲染,底部总计数量和价格

shift+鼠标右键,打开powershell,新建项目

自定义

只有一个页面,不涉及路由,勾选vuex,css,babel

无需保存预设

回车项目开始创建

项目用vscode打开

将src里的内容全部清空

将第七天的课程准备代码复制粘贴到src中

刷新页面,可看到购物车案例

vuex分模块存储数据

新建模块并挂载。新建modules文件夹,该文件夹下新建cart.js模块。

生成后端接口

全局安装json-server

新建db文件夹(用于存放数据源),将准备好的 index.json(在第七天课程中有) 放到文件夹中

提供数组包对象的格式,json-server就能基于这些数据提供增删改查全套结果

注意:json格式 "键"必须用双引号引起来

index.json处打开powershell

可以看到有两个接口了 ,启动index.json的窗口不能关,否则接口访问不了

请求获取数据存入vuex,映射渲染

因为以前安装的esLint版本与axios版本冲突导致axios安装不了,无妨 ,--force强制安装 。安装完成axios之后再启动一次serve

在App.vue的created中已进入页面就调用actions执行异步请求数据,actions调用mutations将获取的数据写入到list中

获取数据之后进行渲染

  • 用辅助函数获取 cart.js中的数据 list,然后v-for进行渲染
  • 在父组件中定义的子组件标签通过 :item自定义属性,将 父组件中访问的数据 传递到子组件,并在子组件进行接收渲染

打开页面检查,打开vue调试工具,找 list中各个对象的属性,以便进行渲染

大的渲染在App.vue中,也就是有几个大块,细节渲染是每个大块里边

修改数量

前端数据通过mutations来修改,后端 index.json中的数据通过发请求来修改(都是在actions中,一个提交更新,一个请求更新)

通过注册点击事件向actions的updateCountAsync方法中传递 id和 实际参数值,因为有两个参数,所以updateCountAsync方法通过对象来接收。

  • 先是向接口发请求修改数据,传过来的 id 作为地址一部分发送请求,然后将后端数据库中的count(此处必须是count,因为是要修改其值)值改为传过来的新值
  • 接下来是向调用mutations中方法,更新本地数据(这里就不要求数据名一样了)

getters底部统计

基于state准备对应getters

使用mapGetters来映射使用

相关推荐
旧梦吟几秒前
脚本网页 地球演化
前端·算法·css3·html5·pygame
xiaoxue..4 分钟前
哨兵节点与快慢指针解决链表算法难题
前端·javascript·数据结构·算法·链表
这是个栗子4 分钟前
【前端知识点总结】前端跨域问题
前端·跨域·cors
尽欢i9 分钟前
踩过坑才懂:前端生成唯一 ID,别用 Date.now ()了!一行代码搞定
前端·javascript
JS_GGbond10 分钟前
解锁 JavaScript 对象的“魔法宝箱”:这些方法让你玩转对象操作
前端·javascript
Doris89312 分钟前
【JS】JS进阶--编程思想、面向对象构造函数、原型、深浅拷贝、异常处理、this处理、防抖节流
开发语言·javascript·ecmascript
是杉杉吖~14 分钟前
《5 分钟上手 React Flex 容器:从 0 搭建响应式卡片列表》
前端·react.js·前端框架
福大大架构师每日一题15 分钟前
rust 1.92.0 更新详解:语言特性增强、编译器优化与全新稳定API
java·javascript·rust
仰望.16 分钟前
vue 甘特图 vxe-gantt table 拖拽任务调整开始日期和结束日期的使用,拖拽任务调整日期
vue.js·甘特图·vxe-ui
阿懂在掘金17 分钟前
早点下班:在 Vue3 中少写 40%+ 的异步代码
vue.js