<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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
        主站蜘蛛池模板: 黄色免费在线网站| 免费看黄网站在线看 | 精品在线视频免费| 91免费资源网站入口| 亚洲fuli在线观看| 免费a级毛片无码a∨蜜芽试看 | 风间由美在线亚洲一区| 日本免费一二区在线电影| 亚洲国产成人精品无码区二本| 成全视频免费高清 | 亚洲av成人无码久久精品| 99在线免费观看视频| 亚洲欧洲国产精品久久| 亚洲中文无码永久免费| 羞羞视频网站免费入口| 亚洲综合无码AV一区二区| 一级毛片不卡片免费观看| 亚洲熟女乱色一区二区三区| 国产精品免费视频一区| 中文字幕a∨在线乱码免费看| 亚洲国产天堂在线观看| 成人免费午夜在线观看| 国产亚洲蜜芽精品久久| 国产AV无码专区亚洲A∨毛片| 97在线观看永久免费视频| 日韩亚洲人成在线综合| 亚洲精品无码永久中文字幕| 毛片免费全部播放无码| 亚洲heyzo专区无码综合| 国产亚洲精品免费视频播放| 99久9在线|免费| 亚洲精品精华液一区二区| 国产亚洲美女精品久久久| 老汉精品免费AV在线播放| 亚洲综合色一区二区三区| 久久亚洲精品无码播放| 波多野结衣在线免费视频| 黄页网址大全免费观看12网站| 国产亚洲A∨片在线观看 | AV大片在线无码永久免费| 深夜福利在线免费观看|