用JS實現一個簡單的購物車小案例

来源:https://www.cnblogs.com/toweiwei/archive/2022/08/06/16557385.html
-Advertisement-
Play Games

該案例主要是實現的功能有:添加商品功能,將商品添加到購物車的功能還有將商品刪除功能,還有就是移出購物車的功能 該案例實現的難點是將商品添加到購物車列表的時候 數量的增加,當購物車有該商品的時候就進行累加操作,沒有該商品就賦值為1. 上代碼: <!DOCTYPE html> <html lang="e ...


該案例主要是實現的功能有:添加商品功能,將商品添加到購物車的功能還有將商品刪除功能,還有就是移出購物車的功能

該案例實現的難點是將商品添加到購物車列表的時候 數量的增加,當購物車有該商品的時候就進行累加操作,沒有該商品就賦值為1.

上代碼:

<!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>Document</title>
</head>
<style>
    * {
        padding: 0;
        margin: 0;
    }
    ul>li{
        margin-top: 20px;
        list-style: none;
        display: flex;
        flex-direction: row;
        justify-content: space-around;
    }
    ul>li>div{
        width: 120px;
    }
    ul>li>div>a{
        width: 50px;
    }
    .box {
        width: 900px;
        margin: 0 auto;
        border: 1px solid #ccc;
        background-color: skyblue;
    }
</style>

<body>
    <div class="box">
        商品名:<input type="text" placeholder="請輸入商品" class="addGoods">
        價格:<input type="number" class="addGoods">
        描述:<textarea class="addGoods"></textarea>
        圖片:<input type="text" placeholder="請輸入圖片" class="addGoods">
        <button id="save">添加商品</button>

        <ul id="goodList">
            <li>
                <div>id</div>
                <div>商品名</div>
                <div>價格</div>
                <div>描述</div>
                <div>圖片</div>
                <div>操作</div>
            </li>
        </ul>

        <table id="carTB" border="1px">
            <tr>
                <th>商品名</th>
                <th>價格</th>
                <th>描述</th>
                <th>圖片地址</th>
                <th>數量</th>
                <th>操作</th>
            </tr>
        </table>
    </div>
    <script>
        var saveBtn=document.getElementById("save")
        var goodsController=document.querySelectorAll('.addGoods')
        var goods=[]
        var car=[]
        saveBtn.onclick=function(){
            var goodName=goodsController[0].value
            var price=goodsController[1].value
            var info=goodsController[2].value
            var image=goodsController[3].value
            var id=Date.now()
            goods.push({
                goodName,price,info,image,id
            })
            addToGood(goodName,price,info,image,id)
            goodName = goodsController[0].value=''
            price = goodsController[1].value=''
            info = goodsController[2].value=''
            image = goodsController[3].value=''
        }
        var goodList=document.getElementById('goodList')
        function addToGood(goodName,price,info,image,id){
            goodList.innerHTML+=`
            <li>
                <div>${id}</div>
                <div>${goodName}</div>
                <div>${price}</div>
                <div>${info}</div>
                <div>${image}</div>
                <div>
                    <a href="javascript:;" onclick='addToCar(${id})'>加入購物車</a>
                    <a href="javascript:;" onclick='rmCar(${id},goods)'>刪除</a>
                    </div>
            </li>
            `
        }
        
        function addToCar(id){
            var currentGood={}
            for(var good of goods){
                if(good.id==id){
                    currentGood=good
                    break
                }
            }
            var flag=false
            for(var index in car){
                if(car[index].id==currentGood.id){
                    flag=index
                }
            }
            if(flag||flag===0){
                car[flag].count++
                document.querySelectorAll('.count')[flag].innerHTML=car[flag].count
            }else{
                currentGood.count=1
                car.push(currentGood)
                randerToTable(currentGood)
            }  
            
        }

        var tb=document.querySelector('#carTB')
        function randerToTable(good){   
            var keys=['goodName','price','info','image','count']
            var row=tb.insertRow(-1)
            for(var i=0;i<6;i++){
                var cell=row.insertCell(i)
                if(i==5){
                    cell.innerHTML=`<button onclick='rmCar(${good.id},car)'>移除購物車</button>`
                }else{ 
                    cell.innerHTML=good[keys[i]]           
                }
                if(i==4){
                    cell.className='count'
                }
            }
        }
        function rmCar(id,arr){ 
            event.target.parentElement.parentElement.remove()
            var rmIndex
            for(var index in arr){
                if(arr[index]==id){
                    rmIndex=index
                    break
                }
            }
            arr.splice(rmIndex,1)
        }
    </script>
</body>
</html>

效果圖為下

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 規則,點擊投籃目標點,就會有一個球沿著相關拋物線,然後,判斷是否進入籃子里,其實就是一個矩形,直接是按照碰撞檢測來的,碰到就算進去了,對其增加了一個分數統計等功能。 ...
  • 1、await和.result/ .getwaiter() .getresult()的區別 await:Task.Run裡面的邏輯是新開的線程去執行的,await Task.Run後面邏輯都在新開的線程去執行。 private async void MainWindow_Loaded(object ...
  • 在智慧工廠領域,智慧城市領域,都需要對設備進行監控。比如工廠需要對周圍環境溫度、濕度、氣壓、電壓,燈的開關進行監控。這時候就需要物聯網平臺來進行管理。 在智慧工廠領域,寶馬集團通過英偉達的Omniverse平臺在電腦中創建數字孿生工廠,併在數字孿生工廠中進行改變生產線配置、工人動線、倉儲管理等實驗 ...
  • 前言 在進行某些爬蟲任務的時候,我們經常會遇到僅用Http協議難以攻破的情況,比如協議中帶有加密參數,破解需要花費大量時間,那這時候就會用Selenium去模擬瀏覽器進行頁面上的元素抓取 大多數情況下我們用Selenium只是爬取一下頁面上可見的元素信息或者做一些模擬人工的操作,但頁面可見元素的數據 ...
  • 需求背景: 近日,在安裝某軟體過程,發現在安裝過程需要輸入一些信息才能繼續下一步操作,在機器數量較少情況下,我們可以單台登錄上去完成安裝操作,但當機器數量超過一定時,如果再手動登錄操作,就會產生大量重覆性操作,既不能帶來有效學習能力提升,同時也會極大產生不確定性,引發工作效率下降,那麼如何自動化完成 ...
  • getIRC-Best IRC Client for mac是一款實用的IRC客戶端,它由各種獨立的 IRC 伺服器網路(或“網路”)組成,這些機器允許用戶連接到 IRC。 詳情:getIRC-Best IRC Client for mac(IRC客戶端) 簡單介紹 macOS 上的 Interne ...
  • 有人相愛,有人夜裡開車看海,我是leetcode第一題都做不出來 題目 給定一個整數數組 nums 和一個整數目標值 target,請你在該數組中找出 和為目標值 target 的那 兩個 整數,並返回它們的數組下標。 你可以假設每種輸入只會對應一個答案。但是,數組中同一個元素在答案里不能重覆出現。 ...
  • Vue3 使用v-md-editor如何動態上傳圖片了 前端代碼: <v-md-editor :autofocus="true" v-model="blog.content" height="510px" placeholder="請輸入內容" left-toolbar="undo redo cle ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...