Java生鲜电商平台-电商中"再来一单"功能架构与详细设计(APP/小程序)
说明:在实际的业务场景中(无论是TO B还是TO C)不管是休闲食品、餐饮、水果、日用百货、母婴等高频购买行业,还是其他行业,“再来一单”都能够大大缩短买家再次下单的流程,促进转化。
于是就有了针对生鲜电商平台的“再来一单”功能,买家只要在订单列表、订单详情或者支付成功中点击“再来一单”,就可以把订单中的商品再次加入购物车,方便快捷,高效.
上面的话可以总结出来"再来一单“以下几个信息.
1. 再来一单的功能在订单列表或者订单详细里面,或者在支付成功里面存在.
2. 用户点击"再来一单"是把商品加入购物车
3. 目的是通过加入购物车这个快捷的方法来促进用户再次下单,方便与快捷.
那么简约的流程图为:
对此基本流程图,我有了以下的思考:
什么是再来一单?
2. 为什么要做再来一单?
3. 怎么做在来一单?业务逻辑如何判断与处理呢?
4. 最终的代码与实战如何呢?
1. 什么是再来一单呢?
说明:再来一单是根据人类的惯性以及惰性,对已经购买了的产品希望再次方便的下单的一个过程。
2. 为什么要做再来一单?
说明:方便,快捷的服务用户,无论是TOB 还是TOC的用户群体,再来一单有一个非常快捷与高效的功能点击,在促进购买力方面有非常显著的特点与点击量.
3. 怎么做再来一单呢? 业务逻辑如何判断与处理呢?
说明:通过上面分析,我们发现再来一单的功能有如下几个特点:
1. 再来一单的功能在订单列表或者订单详细里面,或者在支付成功里面存在.
2. 用户点击"再来一单"是把商品加入购物车
3. 目的是通过加入购物车这个快捷的方法来促进用户再次下单,方便与快捷.
由于”再来一单“存在任何订单里面,可能有些时间比较长的历史订单,再点击加入购物车以及跳转到购物车的页面中的时候,会出现商品已经下架,商品
价格已经变动等等情况,那么这个时候业务应该如何进行判断与处理呢?
先看下基本的流程图:
其实最核心的判断是三点:
1. 判断商品是否下架。下架的商品简单粗暴的解决,不显示。或者加入购物车的时候,显示商品下架。
2. 判断商品价格是否有改动,不管是否有改动,都需要去获取最新的价格.,这里可以做得比较好的就是把原来的价格进行比较,说明是降价与涨价.
3. 判断是否商品还有库存,没有库存也可以加到商品缺少库存的提醒中,但是不可用作为提交订单的依据。
4. 最终的代码与实战如何呢?
/**
* 再来一单
* @param userId
* @param orderId
*/
@Override
public void copyOrderToCart(Integer userId, Integer orderId) throws ServiceException
{
List<OrderGoods> orderGoodsList = orderGoodsService.getListOrderGoodsByOrderId(orderId); if(CollectionUtils.isEmpty(orderGoodsList))
{
throw new ServiceException(ServiceExceptionCode.PARAM_INVALID.getCode(), "再来一单商品列表不能为空");
} List<Cart> resultCartList = new ArrayList<Cart>();
for(OrderGoods orderGoods : orderGoodsList)
{
//判断商品是否可以购买
Goods goods = goodsService.findById(orderGoods.getGoodsId()); //对象不为空,而且商品在售
if (goods != null && goods.getOnSale())
{
//判断购物车中是否存在此规格商品
Cart existCart = queryExist(goods.getId(), userId);
if (existCart == null)
{
//取得规格的信息,判断规格库存
Cart cart = new Cart();
cart.setUserId(userId);
cart.setGoodsId(orderGoods.getGoodsId());
cart.setGoodsSn(orderGoods.getGoodsSn());
cart.setGoodsName(orderGoods.getGoodsName());
cart.setPicUrl(orderGoods.getPicUrl());
cart.setChecked(true);
cart.setNumber(orderGoods.getNumber());
cart.setPrice(orderGoods.getPrice());
cart.setAddTime(LocalDateTime.now());
cart.setUpdateTime(LocalDateTime.now());
cart.setDeleted(false);
resultCartList.add(cart);
} else
{
//取得商品的库存
int num = existCart.getNumber() + orderGoods.getNumber();
if (num <= orderGoods.getNumber())
{
//如果库存够,更新购物车
existCart.setNumber(num);
cartMapper.updateCart(existCart);
}
}
}
} if(CollectionUtils.isNotEmpty(resultCartList))
{
//批量新增加
cartMapper.batchAddCart(resultCartList);
}
}
相关规则总结如下:
1、买家端小程序订单列表和详情符合条件的订单增加“再来一单”,支持一键把订单中的商品加入购物车;
2、目前支持再来一单的商品为实物商品类型的普通订单,周期购、拼团等营销活动订单不支持;
3、“再来一单”按钮位置根据对应订单状态,根据各操作按钮优先等级排列;
4、点击“再来一单”,把当前订单中的商品批量加入购物车,商品规格、数量、商品留言等信息取当前订单的设置;
5、如果原来购物车中已经有相同商品,“再来一单”不对原商品做删除,在数量上会叠加;
6、点击再来一单时,商品价格、规格信息可能已经发生变更,点击“再来一单”,重新校验,所有营销活动的价格计算目前仅支持限时折扣、自定义会员价、会员折扣;
7、点击再来一单时,如果商品留言字段有增减,会重新校验,不符合条件的商品会提示不支持再来一单;
8、多件商品批量再来一单,如果有部分商品不支持,则会把支持的商品加入购物车,不支持的给出提示。
共同学习QQ群:793305035