javascript+css+html购物车案例

news2024/12/24 20:17:43

javascript代码部分主要实现三部分功能 

1、商品数量增加(减少)同时小计增加(减少)

这部分主要是通过for循环给增加(减少)按钮绑定点击事件

1)点击后计数器自增(自减)

2)计数器数量*对应商品单价 赋值给对应商品小计(涉及到数据类型转换)

parseInt('12ccc') → 12 (该方法常用于截断数值后面的单位)

2、封装一个用于计算总价和总量的函数

1)利用循环函数获取页面所有商品的小计和与数量和

2)将封装函数写进增加(减少)按钮绑定事件里面,使得每次点击都会重新计算小计与数量

注意:该函数要写在for循环外面

3、删除功能 

1)给每个删除事件都要绑定一个点击事件,因此可以与增加减少按钮写在一个循环体内

2)这里主要用到了 父元素.removeChild(子元素)这个方法,这里要分清楚谁是父元素,谁是子元素,一定要找最近的父元素,不要混淆,而且要先获取父元素

3)封装函数也要写在点击事件里面。

这里有个很容易出错的问题:就是删除该列商品后页面中的总价和总商品数量也需要发生对应的改变,因此封装函数需要重新去获取当前页面中的对应商品的数量以及小计,所以我们将获取元素的代码,写在封装函数里面,用于重新获取页面信息。参考局部变量与全局变量的作用域不同,因此不会互相影响。

购物车效果图如下所示: 


 css代码部分

* {
    margin: 0;
    padding: 0;
    }
    table {
        border-spacing: 0;
        border: 1px dashed #ccc;
        width: 600px;
        border-left: 0;
        border-right: 0;
        text-align: center;
        /* 让表格居中 */
        margin: 0 auto;
    }
    td {
        border-spacing: 0;
        border: 1px dashed #ccc;
        border-top: 0;
        border-left: 0;
        border-right: 0;
        width: 100px;
        height: 100px;
    }
    th {
        border-spacing: 0;
        border: 1px dashed #ccc;
        border-left: 0;
        border-right: 0;
    }
    
    ul {
     display: flex;
     justify-content: center;
    }

    li {
    display: flex;
     float: left;
     list-style: none;
     justify-content: center;
   }

   .input {
    height: 15px;
    width: 35px;
    text-align: center;
    background-color: whitesmoke;
    border: 1px solid darkred;
    padding: 0;
    margin: 0;
    line-height: 15px;
   }

   .add {
    height: 17px;
    width: 10px;
    text-align: center;
    background-color: darkred;
    text-align: center;
    color: white;
    line-height: 15px;
    padding: 0;
    margin: 0;
    border:1px solid darkred;
   }

   .reduce {
    height: 17px;
    width: 10px;
    text-align: center;
    background-color: darkred;
    text-align: center;
    color: white;
    line-height: 15px;
    padding: 0;
    margin: 0;
    border:1px solid darkred;
   }

   .foot {
    border: 1px solid #ccc;
    border-top: 0;
    width: 600px;
    height:50px;
    margin: 0 auto;
   }

   .jiesuan {
    height:50px;
    background-color: darkred;
    width: 70px;
    color:white;
    border: 0;
    font-size: 15px;
   }

   .bottom {
    font-size: 15px;
    float:right;
   }

   .jiesuan:hover {
    background-color: plum
   }

   #totalNum {
    color: darkred;
   }

   #total_price {
    color: darkred;
   }
    
   .item:hover {
    background-color: whitesmoke;
   }
   
   .item {
    height: 100px;
   }

html代码部分

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>购物车案例</title>
    <link rel="stylesheet" href="shoppingcar.css">
</head>
<body>
    <table>
        <tr>
         <th><input type="checkbox" class="all">全选</th>
         <th>商品</th>
         <th>单价</th>
         <th>商品数量</th>
         <th>小计</th>
         <th>操作</th>
        </tr>
        <tbody id="carBody">
        <tr class="item">
            <td><input type="checkbox" class="liu"></td>
            <td><img src="./image/1.jpg" width="50%"></td>
            <td class="price">20¥</td>
            <td>
                <ul class="num">
                    <li >
                        <button class="add">+</button>
                    </li>
                    <li class="count">
                        <input type="text" class="input" value="1" readonly>
                    </li>
                    <li >
                        <button class="reduce" disabled>-</button>
                    </li>
                </ul>
            </td>
            <td class="total">1</td>
            <td class="del"><button>删除</button></td>
        </tr>

        <tr class="item">
            <td>
                <input type="checkbox" class="liu">
            </td>
            <td>
                <img src="./image/2.jpg" width="50%">
            </td>
            <td class="price">30¥</td>
            <td>
                <ul class="num">
                    <li >
                        <button class="add">+</button>
                    </li>
                    <li  class="count">
                        <input type="text" class="input" value="1" readonly>
                    </li>
                    <li >
                        <button class="reduce" disabled>-</button>
                    </li>
                </ul>
            </td>
            <td class="total">1</td>
            <td class="del"><button>删除</button></td>
        </tr>

        <tr class="item">
            <td><input type="checkbox" class="liu">
            </td>
            <td>
                <img src="./image/3.jpg" width="50%">
            </td>
            <td class="price">40¥</td>
            <td>
                <ul class="num">
                    <li >
                        <button class="add">+</button>
                    </li>
                    <li class="count">
                        <input type="text" class="input" value="1" readonly>
                    </li>
                    <li >
                        <button class="reduce" disabled>-</button>
                    </li>
                </ul>
            </td>
            <td class="total">1</td>
            <td class="del"><button>删除</button></td>
        </tr>

        <tr class="item">
            <td><input type="checkbox" class="liu">
            </td>
            <td>
                <img src="./image/4.jpg" width="50%">
            </td>
            <td class="price">50¥</td>
            <td>
                <ul class="num">
                    <li >
                        <button class="add">+</button>
                    </li>
                    <li  class="count">
                        <input type="text" class="input" value="1" readonly>
                    </li>
                    <li >
                        <button  class="reduce" disabled>-</button>
                    </li>
                </ul>
            </td>
            <td class="total">1</td>
            <td class="del"><button>删除</button></td>
        </tr>
       </tbody>
     </table>
     <div class="foot">
        <div class="bottom">
        已经选中<i id="totalNum">0</i>件商品&nbsp;&nbsp;&nbsp;商品总价为:<i id="total_price">0¥</i>
       <button class="jiesuan">去结算</button>
       </div>
     </div>

</body>
    <script>
        let adds = document.querySelectorAll('.add')
        let reduces = document.querySelectorAll('.reduce')
        let prices =document.querySelectorAll('.price')
        let total_price = document.querySelector('#total_price')
        let totalNum = document.querySelector('#totalNum')
        let dels = document.querySelectorAll('.del')
        let totals =document.querySelectorAll('.total')
        let inputs = document.querySelectorAll('.input')
        // 获取父元素
        let carBody = document.querySelector('#carBody')
        let liu = document.querySelectorAll('.liu')
        let all = document.querySelector('.all')
        
        all.addEventListener('click',function(){
            for(let i = 0; i < liu.length; i++){
                liu[i].checked = all.checked
            }
        })

        for( let i = 0; i < adds.length ; i++){
              totals[i].innerHTML = prices[i].innerHTML
               // 增加
              adds[i].addEventListener('click',function(){
              inputs[i].value++
              reduces[i].disabled = false
              totals[i].innerHTML = parseInt(prices[i].innerHTML)*inputs[i].value + '¥'
             // 计算现在总额
             sumMoney()
             })
              // 减少
              reduces[i].addEventListener('click',function(){
              inputs[i].value--
              totals[i].innerHTML = parseInt(prices[i].innerHTML)*inputs[i].value + '¥'
               if(inputs[i].value <= 1) {
                reduces[i].disabled = true
               }
              // 计算现在总额
              sumMoney()
             })
             // 删除
              dels[i].addEventListener('click',function(){
                 // 父元素.removeChild(子元素)
                 carBody.removeChild(this.parentNode)
                 sumMoney()
              })
            }
             
              // 总价 result函数
            function sumMoney(){
                let totals =document.querySelectorAll('.total')
                let inputs = document.querySelectorAll('.input')
                let num = 0
                let sum = 0
                for( let i = 0; i < totals.length; i++){
                    sum = sum + parseInt(totals[i].innerHTML)
                    num = num + Number(inputs[i].value)
                }
                total_price.innerHTML = sum + '¥'
                totalNum.innerHTML = num
              }
              sumMoney()
    </script>
</html>

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

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

相关文章

【深度学习:开源数据注释】开源数据注释完整指南

【深度学习&#xff1a;Automated Data Annotation】开源数据注释完整指南 什么是开源数据标注工具&#xff1f;您会使用开源标签工具做什么&#xff1f;主要的开源数据标注工具有哪些&#xff1f;CVATMONAI LabelLabelMeRIL-ContourSefexa 使用开源注释工具的优点和缺点是什么…

Sora:将文本转化为视频的创新之旅

一.能力 我们正致力于让 AI 掌握理解和模拟物理世界动态的能力&#xff0c;旨在培养能够协助人们解决现实世界互动问题的模型。 介绍 Sora——我们开发的文本到视频转换模型。Sora 能够根据用户的输入提示&#xff0c;生成最长达一分钟的高质量视频内容。 目前&#xff0c;Sora…

Gitee入门之工具的安装

一、gitee是什么&#xff1f; Gitee&#xff08;码云&#xff09;是由开源中国社区在2013年推出的一个基于Git的代码托管平台&#xff0c;它提供中国本土化的代码托管服务。它旨在为个人、团队和企业提供稳定、高效、安全的云端软件开发协作平台&#xff0c;具备代码质量分析、…

揭开Markdown的秘籍:引用|代码块|超链接

&#x1f308;个人主页&#xff1a;聆风吟 &#x1f525;系列专栏&#xff1a;Markdown指南、网络奇遇记 &#x1f516;少年有梦不应止于心动&#xff0c;更要付诸行动。 文章目录 &#x1f4cb;前言一. ⛳️Markdown 引用1.1 &#x1f514;引用1.2 &#x1f514;嵌套引用1.3 &…

【Python---六大数据结构】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;Python &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; Python---六大数据结构 往期内容前言概述一下可变与不可变 Number四种不同的数值类型Number类型的创建i…

【Spring篇】Spring的创建与使用

目录 一 . 创建Spring项目 二 . Bean 对象存放到 Spring 三 . 从Spring中读到Bean 经过前⾯的学习我们已经知道了&#xff0c;Spring 就是⼀个包含了众多⼯具⽅法的 IoC 容器。既然是容器那么 它就具备两个最基本的功能&#xff1a; 将对象存储到容器&#xff08;Spring&am…

optee CA/TA flow

以 TEEC_InvokeCommand 为例 CA—normal world EL0 //imx-optee-client\libteec\src\tee_client_api.c TEEC_InvokeCommandioctl(session->ctx->fd, TEE_IOC_INVOKE, &buf_data)通过syscall陷入内核态driver linux driver—normal world EL1 tee_ioctl // drive…

一些方便的记录

如何在ubutun上安装qq 在QQ官网选择QQ Linux版本&#xff0c;然后选择X86下的deb类型文件进行下载 sudo dpkg -i linuxqq_3.2.5-21453_amd64.deb64 根据下载的版本不同对其进行更改 运行上述命令后显示应用程序可以看到安装后的QQ面板如何卸载安装在gnuradio的lora组件 - 进入…

php基础学习之可变函数(web渗透测试关键字绕过rce和回调函数)

可变函数 看可变函数的知识点之前&#xff0c;蒟蒻博主建议你先去看看php的可变变量&#xff0c;会更加方便理解&#xff0c;在本篇博客中的第五块知识点->php基础学习之变量-CSDN博客 描述 当一个变量所保存的值刚好是一个函数的名字&#xff08;由函数命名规则可知该值必…

Eclipse Version: 2023-03 (4.27.0) JDK19 Tomcat10.2

Eclipse Version: 2023-03 (4.27.0) JDK19 Tomcat10.2

电子元器件基础5---二极管

除了电阻、电容和电感等线性元器件之外,还有二极管、三极管这些常用的非线性器件广泛应用于日常生活中。那么今天我们来介绍以下二极管这一常用的电子元器件。 一、二极管概念 二极管是用半导体材料(硅、硒、锗等)制成的一种电子器件 。二极管有两个电极,正极,又叫阳极;负…

07-k8s中secret资源02-玩转secret

一、回顾secret资源的简单实用 第一步&#xff1a;将想要的数据信息【key&#xff1a;value】中的value值&#xff0c;使用base64编码后&#xff0c;写入secret资源清单中&#xff1b; 第二步&#xff1a;创建secret资源&#xff1b; 第三步&#xff1a;pod资源引用secret资源&…

VMware Workstation 17.0 虚拟机安装MS-DOS 7.1完整详细步骤图文教程

VMware Workstation 17.0 虚拟机安装MS-DOS 7.1完整详细步骤图文教程 一、配置MS-DOS虚拟机机器环境二、安装MS-DOS磁盘操作系统 一、配置MS-DOS虚拟机机器环境 1.打开VMware Workstation Pro 2.新建虚拟机 3.建议选择【典型】&#xff0c;之后点击【下一步】 关于【自定义…

嵌入式Qt Qt中的信号处理

一.Qt中的信号处理 Qt消息模型&#xff1a; - Qt封装了具体操作系统的消息机制 - Qt遵循经典的GUI消息驱动事件模型 Qt中定义了与系统消息相关的概念; Qt中的消息处理机制&#xff1a; Qt的核心 QObject::cinnect函数&#xff1a; Qt中的“新”关键字&#xff1a; 实验1 初探…

[职场] 会计学专业学什么 #其他#知识分享#职场发展

会计学专业学什么 会计学专业属于工商管理学科下的一个二级学科&#xff0c;本专业培养具备财务、管理、经济、法律等方面的知识和能力&#xff0c;具有分析和解决财务、金融问题的基本能力&#xff0c;能在企、事业单位及政府部门从事会计实务以及教学、科研方面工作的工商管…

RK3568笔记十七:LVGL v8.2移植

若该文为原创文章&#xff0c;转载请注明原文出处。 本文介绍嵌入式轻量化图形库LVGL 8.2移植到Linux开发板ATK-RK3568上的步骤。 主要是参考大佬博客&#xff1a; LVGL v8.2移植到IMX6ULL开发板_lvgl移植到linux-CSDN博客 一、环境 1、平台&#xff1a;rk3568 2、开发板:…

Java解决下降路径最小和

Java解决下降路径最小和 01 题目 给你一个 n x n 的 方形 整数数组 matrix &#xff0c;请你找出并返回通过 matrix 的下降路径 的 最小和 。 下降路径 可以从第一行中的任何元素开始&#xff0c;并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多相隔一列…

net6 core webapi部署到iis

1.設定發佈的選項 2.安裝Hosting Bundle .NET Core 託管捆綁包是 .NET Core 執行時期和ASP.NET Core 模組的安裝程式。該捆綁包允許 ASP.NET Core 應用程式與 IIS 一起運行。 3.設定網站

自动更改由VSCode调试器创建的默认launch.json文件

File -> Preference -> Settings 修改下面的部分

SpringCloud之Feign发送Http请求

文章目录 http客户端Feign使用步骤自定义Feign的配置Feign的性能优化Feign的性能优化-连接池配置 Feign的最佳实践 http客户端Feign Feign的介绍&#xff1a; Feign是一个声明式的http客户端&#xff0c;官方地址&#xff1a;https:/github.com/OpenFeign/feign 其作用就是帮助…