基於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
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...