133 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			133 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | ||
|   <view>
 | ||
|     <!-- 如果商品没有加入购物车 -->
 | ||
|     <block v-if="getCheckProductExists">
 | ||
|       <u-button size="mini" type="warning" @click="addShopCart">加入购物车</u-button>
 | ||
|     </block>
 | ||
|     <block v-else>
 | ||
|       <u-number-box
 | ||
|           ref="uNumber"
 | ||
|           v-model="skuNumValue"
 | ||
|           :disabled-input="true"
 | ||
|           :input-height="40"
 | ||
|           :input-width="60"
 | ||
|           :max="getMax"
 | ||
|           :min="0"
 | ||
|           :size="20"
 | ||
|           @minus="changeSkuNumMinus"
 | ||
|           @plus="changeSkuNumPlus"
 | ||
|       ></u-number-box>
 | ||
|     </block>
 | ||
| 
 | ||
|     <u-modal ref="confirmModal" v-model="showConfirmModal" :async-close="true" :show-cancel-button="true"
 | ||
|              @cancel="modalCancel" @confirm="modalConfirm">
 | ||
|       <view class="u-flex u-row-center u-m-20">确认删除该商品?</view>
 | ||
|     </u-modal>
 | ||
|   </view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| import {mapGetters, mapActions} from 'vuex';
 | ||
| 
 | ||
| export default {
 | ||
|   name: 'AddToCart',
 | ||
|   data() {
 | ||
|     return {
 | ||
|       id: 0,
 | ||
|       isCart: false,
 | ||
|       showConfirmModal: false
 | ||
|     };
 | ||
|   },
 | ||
|   props: {
 | ||
|     shopDetail: {
 | ||
|       type: Object,
 | ||
|       default: () => {
 | ||
|         return {};
 | ||
|       }
 | ||
|     },
 | ||
|     // 在购物车页面的时候,使用带活动的购物车将传递的不再是商品的id
 | ||
|     // 商品详情信息中没有id,而是skuId
 | ||
|     skuId: {
 | ||
|       type: Number,
 | ||
|       default: null
 | ||
|     }
 | ||
|   },
 | ||
|   computed: {
 | ||
|     ...mapGetters('cartModule', ['checkProductExists', 'getProductSkuNum']),
 | ||
|     // 检查是否存在商品于购物车
 | ||
|     getCheckProductExists() {
 | ||
|       return !this.checkProductExists(this.id);
 | ||
|     },
 | ||
|     // 商品加入购物车的数量
 | ||
|     skuNumValue: {
 | ||
|       get() {
 | ||
|         return this.getProductSkuNum(this.id);
 | ||
|       },
 | ||
|       set(value) {
 | ||
|       }
 | ||
|     },
 | ||
|     // 最大可加入购物车的数量
 | ||
|     getMax() {
 | ||
|       let perLimit = this.shopDetail.perLimit;
 | ||
|       // 秒杀商品与普通商品购买上限判断字段不同
 | ||
|       if (this.shopDetail.skuType === 1) {
 | ||
|         perLimit = this.shopDetail.seckillSkuVo && this.shopDetail.seckillSkuVo.seckillLimit
 | ||
|       }
 | ||
|       return perLimit;
 | ||
|     }
 | ||
|   },
 | ||
|   methods: {
 | ||
|     ...mapActions('cartModule', ['addShopAction', 'changeSkuNumAction']),
 | ||
|     // 添加到购物车
 | ||
|     addShopCart() {
 | ||
|       if (this.skuId) {
 | ||
|         this.shopDetail.id = this.skuId;
 | ||
|       }
 | ||
|       this.addShopAction(this.shopDetail);
 | ||
|     },
 | ||
|     // 购物车数量递减
 | ||
|     changeSkuNumMinus(e) {
 | ||
|       // 如果是购物车中进行递减操作,并且购物车数量为0,那么需要弹出确认框
 | ||
|       if (e.value < 1 && this.isCart) {
 | ||
|         this.showConfirmModal = true;
 | ||
|       } else {
 | ||
|         this.changeSkuNumAction({skuId: this.id, value: -1, currentBuyNum: e.value, isCart: this.isCart});
 | ||
|       }
 | ||
| 
 | ||
|     },
 | ||
|     // 购物车数量递增
 | ||
|     changeSkuNumPlus(e) {
 | ||
|       this.changeSkuNumAction({skuId: this.id, value: 1, currentBuyNum: e.value, isCart: this.isCart});
 | ||
|     },
 | ||
|     // 确认删除商品模态框
 | ||
|     modalConfirm() {
 | ||
|       this.showConfirmModal = false;
 | ||
|       this.changeSkuNumAction({skuId: this.id, value: -1, currentBuyNum: 0, isCart: this.isCart});
 | ||
|     },
 | ||
|     // 取消删除商品模态框,只需要将商品购买数修改回初始值
 | ||
|     modalCancel() {
 | ||
|       this.showConfirmModal = false;
 | ||
|       // 重新设置u-number-box的初始值
 | ||
|       this.$refs.uNumber.$data.inputVal = 1;
 | ||
|     },
 | ||
|   },
 | ||
|   watch: {
 | ||
|     // skuId是在购物车频道使用,如果是商品列表,是id
 | ||
|     skuId: {
 | ||
|       handler(newVal, oldVal) {
 | ||
|         if (newVal) {
 | ||
|           this.id = newVal;
 | ||
|           this.isCart = true;
 | ||
|         } else {
 | ||
|           this.id = this.shopDetail.id;
 | ||
|           this.isCart = false;
 | ||
|         }
 | ||
|       },
 | ||
|       immediate: true
 | ||
|     }
 | ||
|   }
 | ||
| };
 | ||
| </script>
 | ||
| 
 | ||
| <style lang="scss"></style>
 |