快生活 - 生活常识大全

优惠券设计前端核销篇


  本文分别对优惠券核销和前端页面进行了介绍。
  一、优惠券核销
  优惠券核销主要在订单提交时进行,需要进行以下三个方面的判定和计算:
  可用判定:判定订单的时间、商品、金额等维度是否符合优惠券的要求。一般在进入确定订单页面时,即进行相关校验。
  抵扣计算:优惠券在订单中实际抵扣的金额计算,主要涉及到与其他优惠活动,或者积分等叠加计算规则。一般在选择优惠券后进行计算。
  优惠金额分摊:将实际的抵扣金额,按比例分摊至适用范围内的每个商品。主要用于售后退款以及销售数据计算。
  1. 可用判定
  可用判定指优惠券对于订单是否可用,主要进行以下两个校验:
  优惠券是否可用。即优惠券是否在未使用状态,且当前时间在优惠券有效期内;
  订单中适用优惠券的商品是否在优惠券的范围内,适用范围内的商品是否达到满额要求。
  一般在进入确定订单页面前,会对用户持有的所有优惠券进行如上两个校验。并在确定订单页面进行显示。参考下图淘宝和饿了么确定订单页面:
  左图为淘宝确定订单页面,右图为饿了么确定订单页面,两者均在进入确定订单页面前校验了可用优惠券。不同之处在于,淘宝中默认选中了适用的最大金额优惠券,饿了么仅做了可用优惠券提示,并未直接选中。
  2. 抵扣计算
  大多数情况下,优惠券的抵扣计算都是比较简单的。以满减券为例,大多数场景,适用商品总金额减去抵扣金额,不可小于0即可。
  在优惠券可用的基础上,假设m=订单中优惠券范围内商品总价,n=优惠券的抵扣额度。
  则:实际抵扣金额=min(m,n);
  举例:用户持有全场无门槛100元优惠券,商品A每件40元,用户使用优惠券购买两件A,则优惠券实际抵扣金额为80元。
  更为复杂的场景为和其他促销活动叠加生效时,对于订单金额和优惠券抵扣金额的计算。
  举例:
  A商品销售价40,B商品销售价100,C商品销售价80;
  用户持有双11优惠券适用于A,B的优惠券,无门槛300元优惠券;
  B商品每件最高可使用积分以10:1的比例抵扣60元,C商品最高可抵扣50元;
  商城营销活动:双11前30分钟A,C商品首件半价;
  用户在双11前30分钟购买3件A,1件B,2件C时,最高可使用多少积分?优惠券实际抵扣金额为多少?订单最终需要支付多少金额?
  要解决以上问题,需要对促销活动进行分层,可按如下方式进行分层:
  优惠券和其他促销活动按照层级依次进行计算。以后有机会针对促销活动进行详述,此处不再展开。
  3. 优惠券金额分摊
  优惠券金额分摊指将订单层面的优惠券抵扣金额,按照商品价格比例分摊到各个商品。主要用于计算商品的实付金额,用于售后退款和数据统计。
  优惠券金额分摊的原则是:在适用范围内,按照折后价格进行按比例分摊。
  优惠券金额分摊是比抵扣计算更加复杂的过程。仅从优惠券层面分摊,假设商品1单价为m,订单中优惠券范围内商品总价为n,优惠券实际抵扣金额为x,则:
  一件商品1的分摊优惠券抵扣金额y=(m/n)*x。
  值得注意的是:对于分摊时小数点取整时,需要在保持总值不变的情况下进行大入小舍,单纯进行四舍五入会产生误差。
  举例:
  商品A和B,均为10元,优惠券为满20减11.11,则按照分摊计算方式,
  A和B的抵扣金额均y=(10/20)*11.11=5.555
  如果单纯进行分位的四舍五入到5.56,会导致分摊后的优惠券之和大于订单优惠券抵扣额度。此种情况一般的处理方式为,随机A和B其中一个进1,一个舍掉,保证能够总账能够对应。
  二、优惠券前端设计
  前端设计仅做简述参考,主要涉及到券包和抵扣页面和消息通知。
  1. 我的优惠券
  上图为一种较为简洁的设计方式,适用于优惠券数量相对较少的情况,比较清晰明了。
  2. 抵扣过程
  确定订单页面自动选中最大可抵扣优惠券,用户也可以重新选择其他优惠券,或不使用优惠券。
  3. 推送通知
  推送通知主要起到提醒用户的作用,优惠券相关的提醒场景有两个:
  新优惠券。用户获得系统发放的优惠券时,进行通知提醒;
  过期提醒。优惠券即将过期时,进行提醒使用。
  小结
  核销是优惠券生命周期的重要一环,与订单关系密切,同时与其他促销活动也有着复杂的关联。下一篇将从数据角度对优惠券进行阐述,敬请期待。
  优惠券设计前序三篇:
  整体框架:《优惠券设计:整体框架篇》
  优惠券模板:《优惠券设计:优惠券模板篇》
  优惠券活动:《优惠券设计:优惠券活动篇》
网站目录投稿:宛亦