【vue】购物车案例优化

news2024/11/24 9:04:40

对 购物车案例 进行优化

  • watch实现全选/取消全选
  • watch实现全选状态的检查
  • computed计算总价格

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        <table>
            <thead>
                <tr>
                    <!-- 全选 -->
                    <!-- <td><input type="checkbox" @click="selectAll" v-model="data.selected"></td> -->
                    <td><input type="checkbox" v-model="data.selected"></td>

                    <td>商品名称</td>
                    <td>商品价格</td>
                    <td>库存</td>
                    <!-- colspan2: 单元格跨度为2 -->
                    <td colspan="2">操作</td>
                </tr>
            </thead>
            <tbody>
                <tr v-for="(item, index) in data.list" :key="item.id">
                    <td>
                        <!-- <input type="checkbox" :value="item" v-model="data.checkboxList" @change="checkSelect"> -->
                        <input type="checkbox" :value="item" v-model="data.checkboxList">
                    </td>
                    <td>{{item.name}}</td>
                    <td>{{item.price}}</td>
                    <td>{{item.stock}}</td>
                    <td>
                        <button @click="sub(item)">-</button>
                        {{item.number}}
                        <button @click="add(item)">+</button>
                    </td>
                    <td>
                        <button @click="del(index,item.id)">删除</button>
                    </td>
                </tr>

            </tbody>
            <tfoot>
                <tr>
                    <td>总价格: {{totalPrice}}</td>
                </tr>
            </tfoot>
        </table>
    </div>

    <script type="module">
        import { createApp, reactive, ref, watch, computed } from './vue.esm-browser.js'
        createApp({
            setup() {
                const data = reactive({
                    selected: false,//全选?
                    checkboxList: [],//购物车中的商品
                    list: [{
                        id: 1,//编号
                        name: '洗衣机',//名字
                        price: 10000,//价格
                        number: 1,//数量
                        stock: 10//库存
                    },
                    {
                        id: 2,
                        name: '电冰箱',
                        price: 20000,
                        number: 2,
                        stock: 8
                    },
                    {
                        id: 3,
                        name: '空调',
                        price: 30000,
                        number: 3,
                        stock: 6
                    },
                    {
                        id: 4,
                        name: '电视',
                        price: 40000,
                        number: 4,
                        stock: 4
                    },
                    {
                        id: 5,
                        name: '微波炉',
                        price: 50000,
                        number: 5,
                        stock: 20
                    }
                    ]
                })
                // //全选/反选
                // const selectAll = () => {
                //     data.selected = !data.selected
                //     if (data.selected) {//全选
                //         data.checkboxList = data.list
                //     }
                //     else {//反选
                //         data.checkboxList = []
                //     }
                // }
                // //取消一个物品时候,自动取消全选
                // const checkSelect = () => {
                //     if (data.checkboxList.length == data.list.length && data.list.length != 0) {
                //         data.selected = true
                //     }
                //     else {
                //         data.selected = false
                //     }
                // }
                let flag = true
                //全选/反选
                watch(() => data.selected, (newValue, oldValue) => {
                    console.log(newValue, oldValue)
                    if (newValue) {//全选
                        data.checkboxList = data.list
                    }
                    else {//反选
                        if (flag) {
                            data.checkboxList = []
                        }

                    }
                })
                //全选检查
                watch(() => data.checkboxList, (newValue, oldValue) => {
                    console.log(newValue, oldValue)
                    console.log(newValue.length)
                    if (newValue.length == data.list.length && data.list.length != 0) {
                        data.selected = true
                        flag = true
                    }
                    else {
                        data.selected = false
                        flag = false
                    }
                })
                //计算总价格
                // const totalPrice = () => {
                //     let total = 0
                //     for (let i = 0; i < data.checkboxList.length; i++) {
                //         total += data.checkboxList[i].price * data.checkboxList[i].number
                //     }
                //     return total
                // }
                //计算总价格
                const totalPrice = computed(() => {
                    let total = 0
                    for (let i = 0; i < data.checkboxList.length; i++) {
                        total += data.checkboxList[i].price * data.checkboxList[i].number
                    }
                    return total
                })
                //增加物品数量
                const sub = (value) => {
                    value.number--
                    if (value.number < 1) {
                        value.number = 1
                    }
                }
                //减少物品数量
                const add = (value) => {
                    value.number++
                    if (value.number > value.stock) {
                        value.number = value.stock
                    }
                }
                //删除物品
                const del = (index, id) => {
                    data.list.splice(index, 1)
                    //过滤器:筛选元素,返回新的数组
                    let newArr = data.checkboxList.filter((value, index) => {
                        return value.id != id//删除id相同的元素
                    })
                    data.checkboxList = newArr
                }
                return {
                    data,
                    // selectAll,
                    // checkSelect,
                    totalPrice,
                    sub,
                    add,
                    del
                }
            }
        }).mount("#app")
    </script>
</body>

</html>

参考

https://www.bilibili.com/video/BV1nV411Q7RX

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1589980.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

javaScript设计模式之简单工厂模式

简单工厂模式(Simple Factory):又叫静态工厂方法&#xff0c;由一个工厂对象决定创建某一种产品对象类的实例。主要用来创建同一类对象。 场景一 假设我们需要计算圆形和矩形的面积 function Circle(radius) {this.radius radius;}Circle.prototype.getArea function() {re…

iMazing如何备份手机资料 iPhone的资料可以传到iPad里吗 iphone备份到mac 苹果导入备份

在当今信息化快速发展的时代&#xff0c;手机已经成为我们生活中不可或缺的一部分。随着资料的积累&#xff0c;备份手机数据成了一个重要的问题。本文将介绍iMazing如何备份手机资料&#xff0c;并为大家解答“iPhone的资料可以传到iPad里吗”这一问题。这不仅可以帮助你有效管…

股票价格预测 | Python使用GAN预测股票价格

文章目录 效果一览文章概述代码设计效果一览 文章概述 生成对抗网络(GAN)是一种强大的机器学习模型,用于生成以假乱真的数据。然而,使用GAN来预测股票价格可能会面临以下挑战: 数据可用性:GAN需要大量的数据进行训练,以便生成准确的输出。对于股票价格预测,历史股票价…

【opencv】示例-image_alignment.cpp 利用ECC 算法进行图像对齐

affine imshow("image", target_image); imshow("template", template_image); imshow("warped image", warped_image); imshow("error (black: no error)", abs(errorImage) * 255 / max_of_error); homography 这段代码是一个利用EC…

MS7336MA高清 HD/全高清 FHD 可选择视频运放与视频同轴线控解码

产品简述 MS7336MA 是一颗集成单通道视频放大器与视频同轴线控解 码为一体的芯片&#xff0c;它内部集成 6dB 增益轨到轨输出驱动器以及 10 阶滤波器&#xff0c;允许同一个输入信号在 -3dB 带宽 35MHz 和 55MHz 之间进行选择控制。视频同轴线控解码内部集成一颗高…

在word中将公式复制后变成了图片怎么解决

是由于文件复制后格式不兼容造成的&#xff0c;需要转化一下。 然后确定就好了

Android T多屏多显——应用双屏间拖拽移动功能(更新中)

功能以及显示效果简介 需求&#xff1a;在双屏显示中&#xff0c;把启动的应用从其中一个屏幕中移动到另一个屏幕中。 操作&#xff1a;通过双指按压应用使其移动&#xff0c;如果移动的距离过小&#xff0c;我们就不移动到另一屏幕&#xff0c;否则移动到另一屏。 功能分析…

考华为数通方向的HCIE认证经验分享

大家好&#xff0c;我是来自安阳工学院20级网络工程的楚同学。在2023年12月6日&#xff0c;我顺利通过了华为数通方向的HCIE认证&#xff0c;在此&#xff0c;我想分享一些备考心得给正在努力备考的小伙伴们。 关于考证的契机 在大一上学期&#xff0c;我们的课程安排在实验…

halcon domain和region总结

1.domain是什么 在halcon中&#xff0c;ROI(Region Of Interest)被称为图像的域(domain)&#xff08;参考《solution_guide_i.pdf》&#xff09;。这个术语来自数学中的定义域&#xff0c;而图像就是函数&#xff0c;本函数负责将坐标映射到像素值&#xff0c;即f(x) gray这样…

记录一次Java中使用P12证书访问https,nginx返回403的问题

目录 1、先使用浏览器导入证书访问&#xff0c;测试证书和密钥是否正确2、编写初始java代码3、结果响应 403 Forbidden4、解决方案 1、先使用浏览器导入证书访问&#xff0c;测试证书和密钥是否正确 成功返回&#xff0c;说明p12证书和密钥是没问题的。 2、编写初始java代码 …

【U8+】用友固定资产卡片拆分提示:未设置对象变量或With block变量。

【问题描述】 用友U8软件中&#xff0c; 操作固定资产模块&#xff0c;针对资产进行卡片拆分的时候&#xff0c; 提示&#xff1a;未设置对象变量或With block变量。 确定后仍然能打开卡片拆分界面&#xff0c;但是界面显示异常看不到拆分明细信息&#xff0c;并且保存后拆分结…

Bug及异常:unity场景角色移动卡墙壁的问题

场景是一个小的杠铃形状封闭空间&#xff0c;美术没有给包围盒&#xff0c;我自己用blender做了一个&#xff08;属于兴趣爱好&#xff09;&#xff0c;如下&#xff1a; 导入场景中使用meshcollider做成空气墙&#xff0c;发现角色移动到角落继续行走会卡角落处&#x…

基于flutter3.x+window_manager+getx桌面端仿macOS系统

flutter3_macui桌面端仿macOS系统实战项目完结啦&#xff01; 原创研发flutter3.19dart3.3window_managergetx等技术构建桌面版macOS系统。支持自定义毛玻璃虚化背景、Dock菜单多级嵌套自由拖拽排序、可拖拽弹窗等功能。 支持macOS和windows11两种风格。 使用技术 编辑器&…

深入理解Apache ZooKeeper与Kafka的协同工作原理

目录 引言 一、ZooKeeper基础概念 &#xff08;一&#xff09;ZooKeeper简介 &#xff08;二&#xff09;ZooKeeper数据结构 &#xff08;三&#xff09;ZooKeeper特点 &#xff08;四&#xff09;应用场景 二、ZooKeeper工作模式 &#xff08;一&#xff09;工作机制 …

装饰器模式:动态扩展对象功能的设计艺术

在面向对象设计中&#xff0c;装饰器模式是一种灵活的结构型模式&#xff0c;用于在不修改对象的基础上&#xff0c;动态地给一个对象添加额外的职责。这种模式通过创建一个包含原始对象的包装对象来实现功能的扩展&#xff0c;是继承关系的一个替代方案。本文将详细介绍装饰器…

循序渐进丨MogDB 数据库带级联从库的集群切换后如何保持原有架构?

生产数据库运行过程中可能会涉及到升级或者打补丁&#xff0c;导致各节点的角色有计划的发生改变。如果集群内角色发生改变&#xff0c;是否还能保持原有架构继续对外提供服务呢&#xff1f;我们来做一下测试。 采用22模式模拟同城两机房部署4节点 MogDB 数据库集群&#xff0c…

FFmpeg: 简易ijkplayer播放器实现--06封装打开和关闭stream

文章目录 流程图stream openstream close 流程图 stream open 初始化SDL以允许⾳频输出&#xff1b;初始化帧Frame队列初始化包Packet队列初始化时钟Clock初始化音量创建解复用读取线程read_thread创建视频刷新线程video_refresh_thread int FFPlayer::stream_open(const cha…

Linux/Tenten

Tenten Enumeration Nmap 扫描发现对外开放了22和80端口&#xff0c;使用nmap详细扫描这两个端口 ┌──(kali㉿kali)-[~/vegetable/HTB/Tenten] └─$ nmap -sC -sV -p 22,80 -oA nmap 10.10.10.10 Starting Nmap 7.93 ( https://nmap.org ) at 2023-12-25 00:52 EST Nmap …

【Python】什么是pip,conda,pycharm,jupyter notebook?conda基本教程

pip--conda--pycharm--jupyter notebook &#x1f343;pip&#x1f343;conda&#x1f343;Pycharm&#x1f343;jupyter notebook&#x1f343;Conda基本教程☘️进入base环境☘️创建一个新的环境☘️激活环境☘️退出环境☘️查看电脑上都安装了哪些环境☘️删除已创建的项目…

Zookeeper实现分布式锁的分析和理解

Zookeeper实现分布式锁 创建临时顺序节点执行create -e -s /znode即可实现分布式锁。 zk中锁的分类 读锁&#xff08;读锁共享&#xff09;&#xff1a;大家都可以读。上锁前提&#xff1a;之前的锁没有写锁写锁&#xff08;写锁排他&#xff09;&#xff1a;只有得到写锁的…