data:image/s3,"s3://crabby-images/295db/295dbbd2ee45bb1efd4d2f185dce6878c77b4acb" alt=""
shift+鼠标右键,打开powershell,新建项目
data:image/s3,"s3://crabby-images/560e5/560e5d374c52d31a0396c570729a24f42b36bcaf" alt=""
data:image/s3,"s3://crabby-images/bb19b/bb19b8b2f0e2f99f4b43f64ec4fa41c7717901ee" alt=""
自定义
data:image/s3,"s3://crabby-images/244a9/244a9f31bf56bb09170a7b79a8c00c3974f8be2d" alt=""
只有一个页面,不涉及路由,勾选vuex,css,babel
data:image/s3,"s3://crabby-images/e2c85/e2c85fb322f27f9c5c134fdbfe470b0cfd9e32b0" alt=""
无需保存预设
data:image/s3,"s3://crabby-images/f4f26/f4f26d71cbd117e4efb8c1a25160829a57e9039f" alt=""
回车项目开始创建
data:image/s3,"s3://crabby-images/20605/206050ec489b3e729ea28473b98bf8591ca54a4a" alt=""
data:image/s3,"s3://crabby-images/cc089/cc089b5bdd1e9de2f1880102d736294f8b0d1dfe" alt=""
data:image/s3,"s3://crabby-images/d8868/d8868e139e3255e506a35a5ef20ab3a6ad8c2a7b" alt=""
data:image/s3,"s3://crabby-images/69680/696806a072e352c262f5e9ef882929cce688bee8" alt=""
项目用vscode打开
data:image/s3,"s3://crabby-images/555b2/555b2620920f8aca459962541496e07363efd56d" alt=""
data:image/s3,"s3://crabby-images/94d19/94d1980c8cc6aa28935d6282bcefc17595a23d9c" alt=""
data:image/s3,"s3://crabby-images/b8c8c/b8c8ca62bfad00019e242f84d6574f7953f7b294" alt=""
将src里的内容全部清空
data:image/s3,"s3://crabby-images/b4bb6/b4bb65263a13eba070a57a90af7b1109f8a22d2c" alt=""
将第七天的课程准备代码复制粘贴到src中
刷新页面,可看到购物车案例
data:image/s3,"s3://crabby-images/68f16/68f1693d0f994f91060ba81a0fdd5a2cfb9b4fdd" alt=""
vuex分模块存储数据
data:image/s3,"s3://crabby-images/0ed37/0ed37f137722c8359191f5e69f4137ffc71efd0f" alt=""
新建模块并挂载。新建modules文件夹,该文件夹下新建cart.js模块。
data:image/s3,"s3://crabby-images/65a9f/65a9fdf14f3a97add45a031aa35e3f42ae148de9" alt=""
data:image/s3,"s3://crabby-images/454b3/454b38bbd30eef79da047010a1e9ddbf14b00989" alt=""
生成后端接口
data:image/s3,"s3://crabby-images/e8021/e802151b104cd3a163594aa15e3fe49c6ce727a6" alt=""
全局安装json-server
data:image/s3,"s3://crabby-images/5c623/5c6236b1cb465722ad34616a7a9be1c92cda4467" alt=""
新建db文件夹(用于存放数据源),将准备好的 index.json(在第七天课程中有) 放到文件夹中
data:image/s3,"s3://crabby-images/1eca9/1eca9e75bd2eaa548478b8b907b83e58abf5c9c2" alt=""
提供数组包对象的格式,json-server就能基于这些数据提供增删改查全套结果
注意:json格式 "键"必须用双引号引起来
data:image/s3,"s3://crabby-images/678e3/678e3cdf86c1637afa2a5dfda4e468ea6a2cd36b" alt=""
index.json处打开powershell
data:image/s3,"s3://crabby-images/ad7b5/ad7b5daddaf33bc23d4a84d87f88b33442f56d9b" alt=""
可以看到有两个接口了 ,启动index.json的窗口不能关,否则接口访问不了
data:image/s3,"s3://crabby-images/da8e1/da8e169d4270d004ab76fe2aaa0357d7fdde6702" alt=""
data:image/s3,"s3://crabby-images/3c0a0/3c0a06e9b0126fd2e5e51a7f01afc1f8ea97606a" alt=""
data:image/s3,"s3://crabby-images/69685/696851e96599842a22abc07a5401dbca58e0e6b6" alt=""
请求获取数据存入vuex,映射渲染
因为以前安装的esLint版本与axios版本冲突导致axios安装不了,无妨 ,--force强制安装 。安装完成axios之后再启动一次serve
data:image/s3,"s3://crabby-images/5c07d/5c07d86d35ceedae21cc4819b2e630ffb3870e7c" alt=""
data:image/s3,"s3://crabby-images/00a37/00a37bd2a4ede6c42cdb8a7e6f90d3ba400905ca" alt=""
在App.vue的created中已进入页面就调用actions执行异步请求数据,actions调用mutations将获取的数据写入到list中
data:image/s3,"s3://crabby-images/b96c9/b96c9f6fe787149399185afab0665bb5d92bda8e" alt=""
获取数据之后进行渲染
- 用辅助函数获取 cart.js中的数据 list,然后v-for进行渲染
- 在父组件中定义的子组件标签通过 :item自定义属性,将 父组件中访问的数据 传递到子组件,并在子组件进行接收渲染
打开页面检查,打开vue调试工具,找 list中各个对象的属性,以便进行渲染
大的渲染在App.vue中,也就是有几个大块,细节渲染是每个大块里边
修改数量
前端数据通过mutations来修改,后端 index.json中的数据通过发请求来修改(都是在actions中,一个提交更新,一个请求更新)
data:image/s3,"s3://crabby-images/7db84/7db843d51301d3102fed46b6e0995276e4ee55b1" alt=""
通过注册点击事件向actions的updateCountAsync方法中传递 id和 实际参数值,因为有两个参数,所以updateCountAsync方法通过对象来接收。
- 先是向接口发请求修改数据,传过来的 id 作为地址一部分发送请求,然后将后端数据库中的count(此处必须是count,因为是要修改其值)值改为传过来的新值
- 接下来是向调用mutations中方法,更新本地数据(这里就不要求数据名一样了)
data:image/s3,"s3://crabby-images/f9d8a/f9d8acbeb5dd22a8e9163a82558c1273a9df9710" alt=""
getters底部统计
基于state准备对应getters
使用mapGetters来映射使用
data:image/s3,"s3://crabby-images/b4d54/b4d5499541192a1a6f8c5ff004324e1d7b9a24ad" alt=""
data:image/s3,"s3://crabby-images/2e2ff/2e2ff9c0a45964e024c6c261627f64fa66502123" alt=""