vant/docs/markdown/zh-CN/coupon.md
2017-12-26 12:39:52 +08:00

3.2 KiB
Raw Blame History

Coupon 优惠券选择器

使用指南

import { CouponCell, CouponList } from 'vant';

Vue.use(CouponCell);
Vue.use(CouponList);

代码演示

基础用法

<!-- 优惠券单元格 -->
<van-coupon-cell
  :coupons="coupons"
  :chosen-coupon="chosenCoupon"
  @click="showList = true"
/>

<!-- 优惠券列表 -->
<van-popup v-model="showList" position="bottom">
  <van-coupon-list
    :coupons="coupons"
    :chosen-coupon="chosenCoupon"
    :disabled-coupons="disabledCoupons"
    @change="onChange"
    @exchange="onExchange"
  />
</van-popup>
const coupon = {
  available: 1,
  discount: 0,
  denominations: 150,
  origin_condition: 0,
  reason: '',
  value: 150,
  name: '优惠券名称',
  start_at: 1489104000,
  end_at: 1514592000
};

export default {
  data() {
    return {
      chosenCoupon: -1,
      coupons: [coupon],
      disabledCoupons: [coupon]
    }
  },

  methods: {
    onChange(index) {
      this.showList = false;
      this.chosenCoupon = index;
    },
    onExchange(code) {
      this.coupons.push(coupon);
    }
  }
}

CouponCell API

参数 说明 类型 默认值 必须
title 单元格标题 String 优惠券码 -
chosen-coupon 当前选中优惠券的索引 Number -1 -
coupons 可用优惠券列表 Array [] -
editable 能否切换优惠券 Boolean true -

CouponList API

参数 说明 类型 默认值 必须
chosen-coupon 当前选中优惠券的索引 Number -1 -
coupons 可用优惠券列表 Array [] -
disabled-doupons 不可用优惠券列表 Array [] -
exchange-button-text 兑换按钮文字 String 兑换 -
exchange-button-disabled 是否禁用兑换按钮 Boolean false -
displayed-coupon-index 滚动至特定优惠券位置 Number - -
show-close-button 是否显示列表底部按钮 Boolean true -
close-button-text 列表底部按钮文字 String 不使用优惠 -
disabled-list-title 不可用券列表标题 String 不可用优惠 -
input-placeholder 输入框文字提示 String 请输入优惠码 -
show-exchange-bar 是否展示兑换栏 Boolean true -

CouponList Event

事件名 说明 参数
change 优惠券切换回调 index, 选中优惠券的索引
exchange 兑换优惠券回调 code, 兑换码

数据格式

优惠券字段说明

key 说明 类型
id 优惠券 id String
name 优惠券名称 String
discount 折扣0为满减券88=>8.8折 Number
denominations 面值0为折扣券单位分 Number
origin_condition 满减条件0为无门槛满XX元可用单位分 Number
start_at 卡有效开始时间 Number
end_at 卡失效日期 Number
reason 不可用原因 String
value 订单优惠金额,单位分 Number