国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue.js實現(xiàn)開發(fā)購物車功能的方法詳解

2019-11-19 12:04:52
字體:
來源:轉載
供稿:網(wǎng)友

本文實例講述了Vue.js實現(xiàn)開發(fā)購物車功能的方法。分享給大家供大家參考,具體如下:

購物車一般包含商品名稱、單價、數(shù)量等信息,數(shù)量可以任意新增或減少,商品項也可刪除,還可以支持全選或多選:

我們把這個小項目分為三個文件:

  • index.html (頁面)
  • index.js (Vue 腳本)
  • style.css (樣式)

1 index.js

首先在 js 中初始化 Vue 實例,整體模板如下:

var app = new Vue({ el: '#app', data: {  ... }, mounted: function () {  ... }, computed: {  ... }, methods: {  ... }});

一般來說,這里的 data 來源于服務端數(shù)據(jù),這里為了簡便,所以直接定義好的數(shù)據(jù):

data: {  /**   * 購物車中的商品列表   */  list: [   {    id: 1,    name: '韓國進口海牌海苔',    price: 39.9,    count: 1   },   {    id: 2,    name: '印尼進口 Nabati 麗巧克(Richoco)休閑零食 巧克力味 威化餅干',    price: 11.8,    count: 1   },   {    id: 3,    name: '菲律賓進口 道吉草 奶油夾',    price: 6.5,    count: 1   }  ],  //選中的商品列表,用于計算總價  checkList: [] }

list 用于展示 購物車中的商品列表。

checkList 用于表示勾選中的商品列表,后面,我們會利用它來計算選中商品的總價。

mounted: function () {  //默認全選  this.checkAll();  this.checkAllElement(document.querySelector(".checkAll"));}

當 mounted 時,默認全選購物車內的所有商品。

computed: { /** * 總價 * @returns {string} */ totalPrice: function () { var total = 0; for (var i = 0; i < this.checkList.length; i++) { var item = this.checkList[i]; total += item.price * item.count; } return total.toLocaleString(); }}

在計算屬性中,我們定義了總價的計算方式,它會綁定勾選的 checkList 來計算總價。之所以使用 toLocaleString 方法,是因為小數(shù)部分會自動四舍五入,而且還會以千分位表示出來,很方便哦O(∩_∩)O~

methods: { /** * 減少購買數(shù)量 * @param index */ reduceCount: function (index) { if (this.list[index].count === 1) return; this.list[index].count--; }, /** * 增加購買數(shù)量 * @param index */ addCount: function (index) { this.list[index].count++; }, /** * 移除商品 * @param index */ remove: function (index) { console.log("remove-index:" + index); this.list.splice(index, 1); //獲取商品序號 var id = index + 1;    //移除實際參與計算的商品 var $checkList = this.checkList; for (var i = 0; i < $checkList.length; i++) { var item = $checkList[i]; if (item.id == id) { $checkList.splice(i, 1); } } }, /** * 全選或全不選 * @param event */ checkAllOrNot: function (event) { if (event.target.checked) {//全選 this.checkAll(); console.log("checkList:" + this.checkList); } else { // 全不選 console.log("全不選"); this.checkInItems('noCheckAll'); this.checkList.splice(0);//清空數(shù)組 } }, /** * 全選 */ checkAll: function () { console.log("全選"); this.checkInItems('checkAll'); this.checkList = this.list.concat();//復制商品列表 }, /** * 全選或全不選 * @param type checkAll:全選;其他:全不選 */ checkInItems: function (type) { var items = document.querySelectorAll('.checkItem'); for (var i = 0; i < items.length; i++) { var item = items[i]; if (type === 'checkAll') { item.checked = true; } else { item.checked = false; } } }, /** * 勾選或不勾選 */ checkItem: function (event, index) { console.log("checkItem"); var element = event.target; var $allCheck = document.querySelector(".checkAll"); if (element.checked) {//勾選,加入已選擇列表 this.checkList.push(this.list[index]); this.checkAllElement($allCheck); } else {//不勾選,從已選擇列表中去除 this.checkList.splice(index, 1); $allCheck.checked = false; } }, /** * 勾選全選框 * @param element */ checkAllElement: function (element) { //如果所有的商品都已被勾選,則勾選全選框 if (this.checkList.length == this.list.length) { element.checked = true; } }}

在 methods 中,我們定義了以下功能方法:

減少與增加購買數(shù)量。在減少購買數(shù)量方法中,我們對當前所對應商品的數(shù)量進行了二次確認,讓代碼變得更加健壯(HTML 模板可能被修改,button 被替換為 div 或者 span,那么 disabled 樣式就變得無效啦)。

移除某件商品。因為購物車中的商品列表與實際勾選的商品列表數(shù)量上有可能存在差異,所以我們必須通過找到商品 ID 再進行刪除。

勾選相關操作(全選、全不選、單選、單不選等)

2 style.css

[v-cloak] { display: none;}table { border: 1px solid #e9e9e9; border-collapse: collapse; border-spacing: 0; empty-cells: show;}th { font: bold 12px "Trebuchet MS", Verdana, Arial, Helvetica, sans-serif; color: #4f6b72; border-right: 1px solid #C1DAD7; border-bottom: 1px solid #C1DAD7; border-top: 1px solid #C1DAD7; letter-spacing: 2px; text-transform: uppercase; text-align: left; padding: 6px 6px 6px 12px; background: #CAE8EA;}td { border-right: 1px solid #C1DAD7; border-bottom: 1px solid #C1DAD7; background: #fff; font-size:14px; padding: 6px 6px 6px 12px; color: #4f6b72;}

這里定義了 v-cloak 樣式,用于解決網(wǎng)絡慢時的閃屏問題。還定義了表格的相關樣式。

3 index.html

接著在 index.html 中引入 Vue 腳本與樣式文件。基本模板如下:

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>購物車</title> <link rel="stylesheet" type="text/css" href="style.css" rel="external nofollow" ></head><body><div id="app" v-cloak> ...</div><script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script><script src="index.js"></script></body></html>

因為有可能購物車中的商品被全部刪除,所以我們在此加了判斷,如果列表為空,則給出友好提示:

<template v-if="list.length"> ...</template><!--當購物車為空時,則提示--><div v-else>購物車內暫時沒有商品</div>

接著用 table 來展示購物車內的商品列表:

<table> <thead> <tr> <th><input id="checkAll" type="checkbox" class="checkAll" @click="checkAllOrNot($event)"></th> <th>序號</th> <th>商品</th> <th>單價</th> <th>數(shù)量</th> <th>操作</th> </tr> </thead> <tbody> <tr v-for="(item,index) in list"> <td><input type="checkbox" class="checkItem" @click="checkItem($event,index)"></td> <td>{{index+1}}</td> <td>{{item.name}}</td> <td>{{item.price}}</td> <td> <button @click="reduceCount(index)" :disabled="item.count===1">-</button> {{item.count}} <button @click="addCount(index)">+</button> </td> <td> <button @click="remove(index)">刪除</button> </td> </tr> </tbody></table><div>總價:¥{{totalPrice}}</div>

使用 v-for 指令,循環(huán)迭代出商品列表。

表格內的每一個勾選框與按鈕都綁定了相應的事件。全選框與每一行的勾選框還傳入了原生 DOM 事件 $event,用于獲取當前所操作的元素。

*這里對減少商品數(shù)量的按鈕進行了判斷,當相應商品的數(shù)量只剩下一個時,綁定 disabled 樣式,讓它變成不可用。

4 演示

本文jsfiddle示例DEMO地址:https://jsfiddle.net/deniro/hvq1y72o/

希望本文所述對大家vue.js程序設計有所幫助。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 汉川市| 双江| 酒泉市| 玉龙| 凤翔县| 扬州市| 鹤庆县| 宁蒗| 苏尼特左旗| 乌兰县| 榆社县| 白沙| 桐庐县| 蚌埠市| 伊春市| 神池县| 稻城县| 防城港市| 五河县| 汉阴县| 新丰县| 云霄县| 申扎县| 上犹县| 桐梓县| 会宁县| 土默特右旗| 若尔盖县| 洛南县| 揭阳市| 长宁县| 合水县| 衡南县| 哈尔滨市| 河池市| 兴和县| 驻马店市| 土默特右旗| 什邡市| 林周县| 大方县|