• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    vue實現仿淘寶結賬頁面實例代碼

    來源:懂視網 責編:小OO 時間:2020-11-27 22:26:07
    文檔

    vue實現仿淘寶結賬頁面實例代碼

    雖然Vue最強大的是組件化開發,但是其實多頁面開發也蠻適合的。下面小編給大家分享vue實現仿淘寶結賬頁面實例代碼,具體內容大家參考下本文。這個demo,是小編基于之前的 vue2.0在table中實現全選和反選文章進行更新后的demo,主要功能呢,是仿照淘寶頁面的結算購物車商品時自動算出合計價格的頁面,具體頁面效果請看下面的動圖:(如果大家發現有什么問題請及時提出幫小穎改正錯誤呦,謝謝啦嘻嘻)。效果圖。更新后的home.vue。
    推薦度:
    導讀雖然Vue最強大的是組件化開發,但是其實多頁面開發也蠻適合的。下面小編給大家分享vue實現仿淘寶結賬頁面實例代碼,具體內容大家參考下本文。這個demo,是小編基于之前的 vue2.0在table中實現全選和反選文章進行更新后的demo,主要功能呢,是仿照淘寶頁面的結算購物車商品時自動算出合計價格的頁面,具體頁面效果請看下面的動圖:(如果大家發現有什么問題請及時提出幫小穎改正錯誤呦,謝謝啦嘻嘻)。效果圖。更新后的home.vue。

    雖然Vue最強大的是組件化開發,但是其實多頁面開發也蠻適合的。下面小編給大家分享vue實現仿淘寶結賬頁面實例代碼,具體內容大家參考下本文。

    這個demo,是小編基于之前的 vue2.0在table中實現全選和反選  文章進行更新后的demo,主要功能呢,是仿照淘寶頁面的結算購物車商品時自動算出合計價格的頁面,具體頁面效果請看下面的動圖:(如果大家發現有什么問題請及時提出幫小穎改正錯誤呦,謝謝啦嘻嘻)

    效果圖:

    更新后的home.vue

    <template>
     <div class="container">
     <div class="checkout-title">
     <span>購物車</span>
     </div>
     <table class="product_table">
     <tbody>
     <template v-for="(list,index) in table_list">
     <tr>
     <td width="7%" min-width="94px" v-if="index===0">
     <input type="checkbox" v-model='checked' @click='checkedAll'>
     </td>
     <td width="7%" v-if="index!==0">
     <input type="checkbox" v-model='checkList' :value="list.id" @click=checkProductFun(index,$event)>
     </td>
     <td width="43%">{{list.product_inf}}</td>
     <td width="10%" v-if="index===0">{{list.product_price}}</td>
     <td width="10%" v-if="index!==0">¥{{list.product_price}}</td>
     <td width="10%" v-if="index===0">{{list.product_quantity}}</td>
     <td width="10%" v-if="index!==0">
     <a class="numbers plus" href="javascript:void(0)" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" @click="changeMoney(index,-1)">-</a>
     <input class="txt_number" type="text" v-model="list.product_quantity" size="1" disabled>
     <a class="numbers reduce" href="javascript:void(0)" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" @click="changeMoney(index,1)">+</a>
     </td>
     <td width="10%">{{list.total_amount}}</td>
     <td width="20%" v-if="index===0">編輯</td>
     <td width="20%" v-if="index!==0">
     <a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="update">修改</a>
     <a href="javascript:void(0)" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" class="delete">刪除</a>
     </td>
     </tr>
     </template>
     </tbody>
     </table>
     <div class="price_total_bottom">
     <div class="price_total_ms">
     <label>合計:{{allProductTotal}}</label>
     <router-link to="/userAddress">結賬</router-link>
     </div>
     </div>
     </div>
    </template>
    <script>
    import userAddress from './address'
    export default {
     components: {
     userAddress
     },
     data() {
     return {
     table_list: [{
     'id': 0,
     'product_inf': '商品信息',
     'product_price': '商品金額',
     'product_quantity': '商品數量',
     'total_amount': '總金額'
     }, {
     'id': '1',
     'product_inf': '女士銀手鏈',
     'product_price': 100,
     'product_quantity': 10,
     'total_amount': 1000
     }, {
     'id': '2',
     'product_inf': '女士銀手鐲',
     'product_price': 200,
     'product_quantity': 5,
     'total_amount': 1000
     }, {
     'id': '3',
     'product_inf': '女士銀耳環',
     'product_price': 50,
     'product_quantity': 10,
     'total_amount': 500
     }],
     checked: false,
     allProductTotal: null,
     checkList: ['1', '3']
     }
     },
     mounted: function() {
     var _this = this;
     // 根據data中默認勾選的checkbox,計算當前勾選的商品總價
     _this.allProductTotal = 0;
     this.checkList.forEach(function(element1, index1) {
     _this.table_list.forEach(function(element2, index2) {
     if (element1 == element2.id) {
     _this.$set(_this.table_list[index2], 'checked', true);
     _this.allProductTotal += element2.product_price * element2.product_quantity;
     }
     });
     });
     },
     methods: {
     checkedAll: function() {
     var _this = this;
     _this.allProductTotal = 0;
     if (_this.checked) { //實現反選
     _this.checkList = [];
     _this.table_list.forEach(function(item, index) {
     if (_this.table_list[index].checked) {
     _this.table_list[index].checked = false;
     }
     });
     } else { //實現全選
     _this.checkList = [];
     _this.table_list.forEach(function(item, index) {
     if (index > 0) {
     _this.checkList.push(item.id);
     if (!_this.table_list[index].checked) {
     _this.$set(_this.table_list[index], 'checked', true);
     } else {
     _this.table_list[index].checked = true;
     }
     if (item.checked) {
     _this.allProductTotal += item.product_price * item.product_quantity;
     }
     }
     });
     }
     },
     checkProductFun(index, event) { //根據checkbox是否勾選,計算勾選后的商品總價
     var _this = this;
     _this.allProductTotal = 0;
     if (event.target.checked) {
     if (!_this.table_list[index].checked) {
     _this.$set(_this.table_list[index], 'checked', true);
     }
     } else {
     if (_this.table_list[index].checked) {
     _this.table_list[index].checked = false;
     }
     }
     this.table_list.forEach(function(item, index) {
     if (item.checked) {
     _this.allProductTotal += item.product_price * item.product_quantity;
     }
     });
     },
     changeMoney: function(index, way) {
     if (way > 0) {
     this.table_list[index].product_quantity++;
     } else {
     this.table_list[index].product_quantity--;
     if (this.table_list[index].product_quantity < 1) {
     this.table_list[index].product_quantity = 1;
     }
     }
     this.calcTotalPrice();
     },
     calcTotalPrice: function() {
     var _this = this;
     _this.allProductTotal = 0;
     this.table_list.forEach(function(item, index) {
     if (index > 0) { //因為第一行為表頭不需要進行計算
     item.total_amount = item.product_price * item.product_quantity; //根據商品數量計算每一個商品對應的總金額
     }
     if (item.checked) {
     _this.allProductTotal += item.product_price * item.product_quantity; //根據是否否選該商品的checkbox,計算總價
     }
     });
     },
     },
     watch: { //深度 watcher
     'checkList': {
     handler: function(val, oldVal) {
     if (val.length === this.table_list.length - 1) {
     this.checked = true;
     } else {
     this.checked = false;
     }
     },
     deep: true
     }
     }
    }
    </script>
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped>
    .container {
     padding: 69px 0 54px 0;
    }
    table {
     border-collapse: collapse;
     border-color: transparent;
     text-align: center;
    }
    .product_table,
    .product_table tbody {
     width: 100%
    }
    .product_table tr:first-child {
     background: #ece6e6;
     color: #e66280;
     font-size: 20px;
    }
    .product_table td {
     border: 1px solid #f3e8e8;
     height: 62px;
     line-height: 62px;
    }
    .product_table a.update:link,
    .product_table a.update:visited,
    .product_table a.update:hover,
    .product_table a.update:active {
     color: #1CE24A;
    }
    .product_table a.delete:link,
    .product_table a.delete:visited,
    .product_table a.delete:hover,
    .product_table a.delete:active {
     color: #ffa700;
    }
    .product_table .txt_number {
     text-align: center;
    }
    .product_table .numbers {
     font-weight: bold;
    }
    .price_total_bottom {
     font-size: 20px;
     padding: 20px 10px;
    }
    .price_total_ms {
     text-align: right;
    }
    .price_total_bottom .price_total_ms label {
     margin-right: 100px;
    }
    .price_total_bottom .price_total_ms a {
     cursor: default;
     text-align: center;
     display: inline-block;
     font-size: 20px;
     color: #fff;
     font-weight: bold;
     width: 220px;
     height: 54px;
     line-height: 54px;
     border: 0;
     background-color: #f71455;
    }
    </style>

    總結

    以上所述是小編給大家介紹的vue實現仿淘寶結賬頁面實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    vue實現仿淘寶結賬頁面實例代碼

    雖然Vue最強大的是組件化開發,但是其實多頁面開發也蠻適合的。下面小編給大家分享vue實現仿淘寶結賬頁面實例代碼,具體內容大家參考下本文。這個demo,是小編基于之前的 vue2.0在table中實現全選和反選文章進行更新后的demo,主要功能呢,是仿照淘寶頁面的結算購物車商品時自動算出合計價格的頁面,具體頁面效果請看下面的動圖:(如果大家發現有什么問題請及時提出幫小穎改正錯誤呦,謝謝啦嘻嘻)。效果圖。更新后的home.vue。
    推薦度:
    標簽: VUE 頁面 代碼
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 日批日出水久久亚洲精品tv| 91精品国产高清久久久久久io| 免费精品无码AV片在线观看| 国产A∨免费精品视频| 久久99精品久久久久久动态图| 欧美精品免费专区在线观看| 亚洲国产精品一区| AV无码精品一区二区三区| 亚洲国产精品久久电影欧美| 精品视频一区二区三区四区五区| 久久伊人精品青青草原高清| 国产精品亚洲一区二区三区在线| 中文国产成人精品久久不卡| 久久精品国产99国产精品| 国产精品你懂的在线播放| 亚洲国产精品嫩草影院| 久久成人国产精品二三区| 国产福利91精品一区二区三区| 国产精品无码成人午夜电影| 久久精品国产亚洲av日韩| 亚洲av日韩精品久久久久久a | 精品福利一区二区三区| 99热成人精品免费久久| 亚洲国产成人久久精品动漫 | 男人的天堂精品国产一区| 精品国产午夜肉伦伦影院| 国产偷伦精品视频| 国内精品视频在线观看| 国产在线精品福利大全| 久久99精品九九九久久婷婷| 久久久精品国产亚洲成人满18免费网站 | jizz国产精品| 久久国产精品国产自线拍免费| 99热精品在线观看| 国产精品久久成人影院| 91麻豆精品视频| 精品午夜久久福利大片| 丰满人妻熟妇乱又伦精品劲| 国产69精品久久久久9999| 国产欧美精品区一区二区三区| 精品人妻少妇嫩草AV无码专区|