<template> <div id="cart" class="has-top"> <!-- <v-header title="購物車" :back="hasBack"> <template v-if="noData===0"> <span @click="onToggleEdit(1)" v-if="!isEdit" slot="right" class="txt fs14 color-black">管理</span> <span @click="onToggleEdit(0)" v-else slot="right" class="txt fs14 color-black">完成</span> </template> </v-header> --> <div class="cart-list-section noData"> <div class="topWhite"> <img src="../../assets/images/status/success.png" alt="" srcset=""> <h2>訂單處理成功</h2> <p>支付金額: <span>¥ {{payMoney}}</span></p> <div class="btm"> <a class="view" @click="view()">查看訂單</a> <a class="back" @click="back()">返回首頁</a> </div> <!-- <template> <no-data :imageSrc="noDataImg" :text="noDataText"> <router-link to="/" tag="div" class="no-data-btn">去挑選好貨</router-link> </no-data> </template> --> </div> <div class="banner"> <router-link to="/beshopkepper"> <img src="../../assets/images/status/hysuccess.jpg" alt="" srcset=""> </router-link> </div> <!--猜你喜歡--> <div class="guess-like" v-if="guessList.length !== 0"> <div class="guess-like-title">- 猜你喜歡 -</div> <div class="guess-like-section"> <!-- <scroller :on-infinite="getGuessList" ref="mainScroller" id="product-comment" class="has-top"> --> <ul class="guess-like-list"> <li class="guess-like-item" v-for="item in guessList" :key="item.skuId" :skuId="item.skuId" @click="onClickItem(item)"> <img :src="item.thumbUrlForShopNow" class="guess-thumbUrl"> <img v-if='item.allStockFlag===1' src="../../assets/images/sellout.png" alt="" class="sellout"> <div class="item-detail"> <div class="guess-title">{{item.productName}}</div> <div class="guess-desc">{{item.intro}}</div> <div class="guess-price-box member"> <span class="guess-price"> <span class="price-ion">¥</span> {{item.minPrice | currency}}/ </span> <span class="guess-marketPrice"> <span class="price-ion">¥</span> {{item.minMarketPrice | currency}} </span> </div> </div> </li> <infinite-loading @infinite="infiniteHandler"> <div slot="no-more">我也是有底線的</div> </infinite-loading> </ul> </div> </div> </div> <main-tab></main-tab> </div> </template> <style scoped> .cart-list-section{ margin: 0px; } .no-data{ margin: 0px; } .topWhite{ background: #fff; text-align: center; padding-top: 1.2rem; padding-bottom: 1.1rem; } .topWhite img{ width: 2.68rem; } .topWhite h2{ font-size: 0.5rem; padding-top: 0.5rem; } .topWhite p{ font-size: 0.42rem; padding: 0.5rem 0; color: #a9a9a9; } .topWhite p span{ color: #ff4e50; } .topWhite .btm{ width: 6.3rem; margin: 0 auto; display: flex; justify-content: space-between; flex-wrap: nowrap; } .topWhite .btm .view{ width: 2.72rem; height: 0.9rem; line-height: 0.9rem; display: block; border: 1px solid #ff4e50; border-radius: 0.45rem; color: #ff4e50; } .topWhite .btm .back{ width: 2.72rem; height: 0.9rem; line-height: 0.9rem; display: block; border: 1px solid #ff4e50; border-radius: 0.45rem; background: #ff4e50; color: #fff; } .banner a{ display: block; } .banner img{ width: 100%; } </style> <script type="text/javascript"> import {XImg} from 'vux' import CartService from '@/services/CartService' import UserService from '@/services/UserService' import util from '../../utils/Common.js' import InfiniteLoading from 'vue-infinite-loading' export default { initWechat: true, components: { 'coupon-dialog': require('@/components/CouponDialog'), XImg, InfiniteLoading, }, data () { return { noDataImg:'../assets/images/cart/cartNull.png', noDataText:"洪荒之力都用上了仍是空空如也~", noData:'', list: [], guessList:[], vipType:'', isEdit: false, hasBack: false, user: {}, levelConfig: [], pageOffset:1, pageSize:15, totalPage: 99, zero:0, defaultImg:require('../../assets/images/default-img-1.png'), orderCode: '', payMoney: 0 } }, computed: { //猜你喜歡加載更多 loadDisabled () { window.scrollTop(0); return this.isLoading && this.page === this.totalPage; }, //合計 total () { if (!this.amount) { return 0 } return this.list.map(store => { return store.skuProductList.filter(sku => sku.selected).reduce((a, b) => { if (b.productType == 3) { return a + b.retailPrice * b.quantity; } return a + b.currentVipTypePrice * b.quantity; }, 0); }).reduce((a, b) => a + b, 0); }, //商品總數量 amount () { return this.list.map(store => { return store.skuProductList.filter(sku => sku.selected) .map(item => item.quantity) .reduce((a, b) => a + b, 0) }).reduce((a, b) => a + b, 0); }, //選中商品的id selectedSkuIds () { return this.list.map(store => { return store.skuProductList.filter(sku => sku.selected).map(sku => sku.skuId); }).reduce((a, b) => [...a, ...b], []); }, //折扣 discountTotal () { return this.list.map(store => { return store.skuProductList.filter(sku => sku.selected).reduce((a, b) => { if (b.productType == 3) { return a } return a + (b.retailPrice - b.currentVipTypePrice) * b.quantity }, 0); }).reduce((a, b) => a + b, 0); }, //全選 allState () { return this.list.filter(sku => sku.selected).length === this.list.length; }, //除去下架和售罄的總數量 allQuantity(){ let num=this.list.map(store => { return store.skuProductList.filter(item=>item.stock!==0&&item.status) .map(item => item.quantity) .reduce((a, b) => a + b, 0) }).reduce((a, b) => a + b, 0); return num; } }, methods: { view() { this.$router.push('/order/detail/'+this.orderCode) }, back() { this.$router.push('/'); }, //商品詳情 onClickItem (item) { util.goToProduct(this,item.productId); }, onNext () { if (this.amount) { let skuIds = this.selectedSkuIds.join(','); window.location.href = '/pay/cart?skuIds=' + skuIds } else { this.showError('請選擇商品'); } }, //獲取購物車列表 getList () { CartService.getList(this, list => { this.list=this.initNotSelected (list); this.noData=(this.list.length > 0)?0:1; this.list.map((store) => { store.skuProductList.map((item) => { if(item.stock!==0&&item.status) { item.visibility = false; }else { item.visibility = true; } }); return store; }); }); }, //獲取猜你喜歡列表 getGuessList () { //this.pageOffset ++; if(this.isLoading) { return ; } if(this.pageOffset > this.totalPage) { this.$refs.mainScroller.finishInfinite(true); return; } this.isLoading = true; CartService.getGuessList(this,this.pageOffset,this.pageSize, list => { this.isLoading = false; this.pageOffset = list.pageOffset; this.totalPage = list.totalPage; if(this.pageOffset === 1){ this.guessList=list.datas; } // if (this.pageOffset >= 2) { // for(let i=0; i<list.datas.length; i++){ // this.$set(this.guessList, this.guessList.length, list.datas[i]); // } // } // this.$refs.mainScroller.setTotal(list.total); // this.$refs.mainScroller.finishInfinite(this.pageOffset >= this.totalPage); }); }, //初始化商品選中 initNotSelected (list) { return list.map((value) => { value.selected = false; value.skuProductList.forEach((item) => item.selected = false); return value; }); }, //是否選中商品 onSelect(sku, store) { if(sku.visibility===false){ sku.selected = !sku.selected; } store.selected = !store.skuProductList.find(item => !item.selected)//選中店鋪 }, //全選 toggleAll () { let selected = !this.allState; return this.list.map((store) => { store.selected = selected; store.skuProductList.map((item) => { if(item.stock!==0&&item.status) { item.selected = selected } }); return store; }); }, //是否選中店鋪 // onSelectStore(store) { // store.selected = !store.selected; // store.items.forEach(item => item.selected = store.selected) // }, //管理商品---編輯 onToggleEdit (num) { this.isEdit = !this.isEdit; if(num===1){ this.list.map((store) => { store.selected = false; store.skuProductList.map((item) => { item.visibility = false; item.selected = false; }); return store; }); }else { this.list.map((store) => { store.selected = false; store.skuProductList.map((item) => { item.selected = false; if(item.stock!==0&&item.status) { item.visibility = false; }else { item.visibility = true; } }); return store; }); } }, //刪除商品 onDelete () { if (this.amount) { CartService.removeBySkuIds(this, this.selectedSkuIds, () => { this.showError('您已成功將商品移除購物車'); this.getList(); }); }else { this.showError('請選擇商品'); } }, // 無限加載 infiniteHandler($state) { let pageSize = 15 this.pageOffset = this.pageOffset + 1 CartService.getGuessList(this,this.pageOffset,this.pageSize, list => { console.log(list) let totalPage = list.totalPage if (this.pageOffset <= totalPage) { if (this.pageOffset > 1) { for(let i=0; i<list.datas.length; i++){ this.guessList.push(list.datas[i]) //this.$set(this.guessList, this.guessList.length, list.datas[i]); } } $state.loaded(); }else{ $state.complete(); } }); }, }, created () { history.pushState(null, null, document.URL); window.addEventListener('popstate', function(e) { if (document.URL.split('/')[document.URL.split('/').length - 1] == 'cart') { history.pushState(null, null, document.URL); } }); /** *@desc 獲取用戶信息(登陸校驗)---->獲取購物車列表、猜你喜歡 *@author zwn *@date 2018/10/10 */ UserService.getInfo( this, (user) => { this.user = user; this.vipType=user.vipType; $(window).scrollTop(0); this.getList(); this.getGuessList(); console.log(this.allQuantity); } ); /** *@desc 子組件更改商品數量以後更新購物車數據 *@author zwn *@date 2018/10/10 */ this.$root.$on('cart.item.amount.update', (skuId, value) => { this.list.forEach((store) => { store.skuProductList.filter(item =>item.skuId === skuId).map(item => { CartService.updateCart(this, item, value, () => { item.quantity = value; }) }); }) }) }, mounted () { this.orderCode = this.$route.query.orderCode this.payMoney = this.$route.query.payMoney / 100 //設置auto 內部能夠滾動,觸發上滑加載更多 // document.querySelector('#home').style.overflow = 'auto' }, beforeRouteUpdate(to, from, next) { next(); document.body.scrollTop=0; this.getSkuInfoById(to.params.skuId, true); } } </script>
外部不要加 overflow-y:autojavascript
外部不要加 overflow-y:autovue
外部不要加 overflow-y:autojava
有多餘的代碼 無論 看主要代碼就好flex