用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
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...