【小兔鲜电商前台 | 项目笔记】第八天

前言:小兔鲜电商前台项目是一个基于Vue的PC端项目,本系列文章我将总结我在这个项目中学到的知识点,写项目笔记。如果你正好在学Vue或想从零搭建一个前端项目,希望本系列文章可以帮助到你。

【小兔鲜电商前台 | 项目笔记】第八天

今日完结:

  • 本地加入购物车实现
  • 本地 - 头部购物车列表渲染
  • 本地 - 头部购物车删除实现
  • 本地 - 头部购物车统计计算
  • 本地 - 列表购物车数据渲染
  • 本地 - 列表购物车单选功能实现
  • 本地 - 列表购物车全选功能实现
  • 本地 - 列表购物车统计数据实现

今日收获:

1.本地添加 | 删除商品

添加商品:

javascript 复制代码
 const addCart = async (goods) => {
  
     // 添加购物车操作
    // 已添加过 - count + 1
    // 没有添加过 - 直接push
    // 思路:通过匹配传递过来的商品对象中的skuId能不能在cartList中找到,找到了就是添加过
    const item = cartList.value.find((item) => goods.skuId === item.skuId)
    if (item) {
      // 找到了
      item.count++
    } else {
      // 没找到
      cartList.value.push(goods)
    }
  
}

删除商品:

javascript 复制代码
const delCart = async (skuId) => {
        // 思路:
      // 1. 找到要删除项的下标值 - splice
      // 2. 使用数组的过滤方法 - filter
      const idx = cartList.value.findIndex((item) => skuId === item.skuId)
      cartList.value.splice(idx, 1)
   }

2.通过计算属性算出商品的总数 | 总价

javascript 复制代码
const allCount = computed(() => cartList.value.reduce((a,c) => a+c.count,0))
const allPrice = computed(() => cartList.value.reduce((a,c) => a+c.count*c.price,0))

3.购物车单选 | 全选功能

单选

javascript 复制代码
<script setup>

const singleCheck = (i,selected) => {
    
    cartStore.singleCheck(i.skuId,selected)
}

</script>
<el-checkbox :model-value="i.selected" @change="(selected)=>singleCheck(i,selected)"/>
javascript 复制代码
// 单选功能
  const singleCheck = (skuId, selected) => {
  // 通过skuId找到要修改的那一项 然后把它的selected修改为传过来的selected
  const item = cartList.value.find((item) => item.skuId === skuId)
  item.selected = selected
}

全选

javascript 复制代码
<script setup>

const allCheck = (selected) => {
     cartStore.allCheck(selected)
}
</script>

 <el-checkbox :model-value="cartStore.isAll" @change="allCheck"/>
javascript 复制代码
// 是否全选计算属性
const isAll = computed(() => cartList.value.every((item) => item.selected))

// 全选功能action
const allCheck = (selected) => {
  // 把cartList中的每一项的selected都设置为当前的全选框状态
  cartList.value.forEach(item => item.selected = selected)
}

4.额外传自定义参数

原生 @change 自带的参数默认只能拿到一个值:是否选中(true/false)

javascript 复制代码
// 默认写法,只能拿到选中状态,拿不到当前行数据 i
@change="singleCheck"

想要传递自定义参数,我们可以用箭头函数包裹

javascript 复制代码
 @change="(selected)=>singleCheck(i,selected)"

总结:

今天学到了日常项目很常见的增,删操作,以及总结商品的数量和总价。

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

相关推荐
逸模5 小时前
告别熬夜手工整理台账,逸模智能归集实现项目数据自动化存档
大数据·运维·人工智能·笔记·其他·信息可视化·自动化
sbjdhjd5 小时前
Redis 主从复制、哨兵高可用与 Cluster 集群部署实验手册
运维·前端·redis·云原生·开源·bootstrap·html
Frostnova丶6 小时前
【算法笔记】数学知识
笔记·算法
乐兮创想 小林6 小时前
企业官网移动端性能优化实战:从 Core Web Vitals 到图片/CDN/响应式的工程清单
前端·性能优化·网站建设·北京网站建设公司
xqqxqxxq6 小时前
哈希表(HashMap)技术学习笔记
笔记·学习·散列表
AOwhisky6 小时前
MySQL 学习笔记(第四期):SQL 语言之多表查询
linux·运维·网络·数据库·笔记·学习·mysql
前端一小卒6 小时前
不手写代码的第 30 天,我才明白前端这个岗位还剩什么
前端·javascript·ai编程
Ajie'Blog6 小时前
Copilot Agent Tasks API 开放:AI 编程开始进入后台任务时代
服务器·前端·javascript·人工智能·copilot·ai编程
老毛肚7 小时前
jeecgboot vue TS & 模板化 04
前端·javascript·vue.js
xian_wwq7 小时前
【学习笔记】「大模型安全:攻击面演化史」第 07 篇-安全左移
人工智能·笔记·学习