使用Nopcommerce为商城添加满XX减XX优惠券功能
公司的电商网站要做个优惠券的功能,nop框架,但我接触nop时间不多,最后还是为了功能而完成了。这中间肯定有很多小问题。
nopcommerce自带的促销功能感觉不是很好,首先优惠券功能放在购物车页面的,如果直接下单就用不了优惠。其次nop的优惠还必须要输入优惠券码很麻烦,最后不满足现在电商主流的单笔订单满xx减xx优惠券功能。但是nop提供了很多基础的方法,我们只要稍作更改就可以达到我们想要的。
优惠券首先需要和用户挂钩,用户可以领取和查看自己的优惠券。优惠券的功能nop基本已经实现了,但是没把优惠券和用户挂钩。
【第一步】我们添加一张表,将优惠券和用户映射。标结构很简单,不多说了。
添加一张表,底层还要添加很多东西,慢慢添加。
【第二步】编写满xx减xx的插件,说实话我接触nop时间不长,插件更不会用。但是nop有个自带的促销插件是商城客户总的订单满足xx就可以使用优惠的,拿过来改造一下就可以了。
【第三步】将service下的几个方法改造
idscountservice下的isdiscountvalid这个方法主要是判断当前用户以及当前优惠券是否满足使用条件,但是他用了一个优惠券码判断,为了使nop代码最小改动,这里我们注释掉就可以了。
接着在ordertotalcalculationservice下重载一个getshoppingcarttotal方法
原来的方法优惠券和优惠金额都是nop自己选一个最佳的优惠方案然后返回这个优惠券和优惠的金额
(hasdiscount那个参数是我加上去的,因为购物车页面也会调用该方法,当显然购物车不应该使用优惠券,所以我加了个参数,在购物车的是为false,不计算优惠信息)
而我希望是自己传一个优惠券然后改价,所以我们得重载一个
applieddiscount就是我们需要传过去优惠券,然后计算价格,可以为空的,用户可能没有优惠券或者优惠券没使用优惠券
【第四步】优惠券领取里面 供用户领取
把所有使用期限未过期的优惠券都赛选出来
用户领取优惠券 ajax调用
【第五步】 订单确认页面,把本订单所有满足的优惠券都赛选出来,并且默认选中最佳优惠
这块我感觉我写的有问题,主要还是想偷懒使用nop的方法
先把商城所有满足条件的优惠券选出来,再根据之前创建的表映射,找到用户拥有的未使用的交集优惠即是可拥的优惠券...
【第六步】修改orderprocessingservice方法
seldiscount新增一个属性,表示当前这个order选择的discount,给orderdiscountamount赋这个discount折扣的金额,用于在后台订单展现订单折扣的金额
顺带在用户后台的订单详情页加上优惠信息
完工。。。第一次写这么长的,肯定好多问题。一边学一边改。
上一篇: vue.js加载新的内容(实例代码)
下一篇: 用ajax实现预览链接可以看到链接的内容