基於vue的購物車清單

来源:https://www.cnblogs.com/angle-xiu/archive/2019/08/25/11408244.html
-Advertisement-
Play Games

//這裡使用的是本地的資源文件,如果需要使用,請將代碼內的資源文件用CDN引入 ...


<!doctype html>
<html>

<head>
    <meta charset="utf-8">
    <link rel="stylesheet" href="node_modules\bootstrap\dist\css\bootstrap.css">
</head>

<body>
    <div id="app">
        <!-- bootstrap  基本樣式+增強樣式-->
        <div class="container">

            <div class="row">
                <h2 class="text-warning">購物車</h2>
                <table class="table table-hover table-bordered">

                    <tr>
                        <th>全選 <input type="checkbox" v-model="checkAll"></th>
                        <td>商品</td>
                        <td>單價</td>
                        <td>數量</td>
                        <td>小計</td>
                        <td>操作</td>
                    </tr>
                    <!-- 括弧與in之間要加空格不然會語法錯誤 -->
                    <tr v-for="(product,index) in products">
                        <td><input type="checkbox" v-model="product.isSelected"></td>
                        <!-- 使用vue指令動態綁定圖片的相關信息 -->
                        <td><img :src="product.productCover" :title="product.productName"
                                alt="1">{{product.productName}}</td>
                        <td>{{product.productPrice}}</td>
                        <td><input type="number" min="1" v-model.number.lazy="product.productCount"
                                onkeyup="this.value=this.value.replace(/\D|^0/g,'')"
                                onafterpaste="this.value=this.value.replace(/\D|^0/g,'')"></td>
                        <!-- 通過過濾器展示更好地效果 -->
                        <td>{{product.productCount*product.productPrice | toFixed(2)}}</td>
                        <td><button type="button" class="btn btn-danger" @click='removes(product)'>刪除</button></td>
                    </tr>
                    <tr>
                        <td colspan="6">總價格:{{sum | toFixed(2)}} </td>
                    </tr>
                </table>
            </div>

        </div>
    </div>
</body>
<!-- vue基於依賴關係引入位置放哪都行 -->
<script src="node_modules\axios\dist\axios.js"></script>
<script src="node_modules\vue\dist\vue.js"></script>
<script>
    let vm = new Vue({
        el: '#app',
        // 當給全選賦值時應要影響其他人的變化,當頁面刷新時,時根據下麵的
        // checkbox計算出來的結果給全選賦值
        computed: { //放在computed中最後也會放在vm上,不能與methods等重名
            checkAll: {
                //當products變化會重新計算
                get() { //get和set this指向實例,v-model會獲取checkAll得值,會調用get方法
                    return this.products.every(p => p.isSelected);
                },
                set(val) { //當我們給checkbox賦值的時候調用,val等於checkAll的值
                    this.products.forEach(p => p.isSelected = val)
                }
             
            }, 
              //sum的值會被緩存
            sum() { //將計算屬性寫成函數則預設調用get
                return this.products.reduce((pre, next) => {
                    if (!next.isSelected) return pre;
                    return pre + next.productPrice * next.productCount;
                }, 0)
            }
        },
        filters: {
            toFixed(input, num) { //第二個參數為小數點個數
                return '' + input.toFixed(num);
            }
        },
        //專門用來發送AJAX的方法
        created() { //數據初始化會被調用,this指向的也是vm實例,鉤子函數
            this.getData();
        },
        data: {
            products: [],
        },
        methods: {
            removes(p) {
                this.products = this.products.filter(item => item !== p);
            },
            getData() {
                axios.get(
                        'https://www.easy-mock.com/mock/5d537a1cf651bc6ff265fb77/example/result/cart.json')
                    .then((res) => {
                        this.products = res.data.data; //這裡需要根據自己用的介面返回的數據來賦值
                        // console.log(res.data);

                    }).catch((err) => {
                        console.log(err); //這裡應使用箭頭函數,this才能指向vm實例
                    });
            }
        }
    });
</script>

</html>

//這裡使用的是本地的資源文件,如果需要使用,請將代碼內的資源文件用CDN引入

 


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

-Advertisement-
Play Games
更多相關文章
  • ``` ``` ...
  • reduce(收斂):接收一個回調函數作為累加器,數組中的每個值(從左到右)開始縮減,最終為一個值,是ES5中新增的又一個數組逐項處理方法。 reduce(callback,initialValue) callback(一個在數組中每一項上調用的函數,接受四個函數:) previousValue(上 ...
  • 簡易萬年曆這個案例是比較有意義的,雖然是個小demo,但涵蓋的知識是一點也不少啊!需要靜下心來好好理解,完全理解下來,就會覺得也沒那麼難,理解了這個demo,後續很多東西都知道怎麼寫了。好啦,先上HTMl部分的代碼。 樣式可以自己更改哈! 下麵是javascript的代碼,會加上註釋,以防小白白看不 ...
  • React 中 setState()詳細解讀 對於 setState() 相信伙伴們都用過,它是 React 官方推薦用來更新組件 state 的 API,但是對於 setState() 你真的瞭解嗎?且待我慢慢詳聊一番。 setState() 官方用法指南 語法1: updater:函數類型,返回 ...
  • js中\=\=和\=\=\=區別 簡單來說: \=\= 代表相同, \=\=\=代表嚴格相同, 為啥這麼說呢, 這麼理解: 當進行雙等號比較時候: 先檢查兩個操作數數據類型,如果相同, 則進行\=\=\=比較, 如果不同, 則願意為你進行一次類型轉換, 轉換成相同類型後再進行比較, 而===比較時, ...
  • jQuery跳轉到另一個頁面 1.我們可以利用http的重定向來跳轉 window.location.replace(" "https://www.cnblogs.com/pythonywy/" "); 2.使用href來跳轉 window.location.href = " "https://ww ...
  • html 基礎標簽 單標簽 1.註釋標簽: <! 註釋信息 看不到 ctrl+/ <! 網頁頭部導航盒子 換行標簽: 橫線標簽: 標題標簽: 段落標簽: 表示強調標簽: 文字 屬性:文字加顏色 color:改變文字顏色 size:改文字大小屬性 例如:文字 文本加粗顯示:或者 文字斜體顯示: 或 下 ...
  • django搭建BBS 登入&驗證碼的生成 文件結構 app 介面 migrations _\_inint\_\_.py admin.py apps.py bbsform.py models.py tests.py views.py avatar BBS \_\_inint\_\_.py setti ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...