问题描述:在制作商品支付的时候遇到了需要使用优惠券抵扣的功能,如果用户有多种优惠券需要自动帮用户选择最佳的优惠券,在用户不损失较大金额优惠券前提下选择最接近的金额。
解决方法:
//选择最优的优惠券
choiceCoupons(couponsDataList,sessionMoney){
sessionMoney=parseFloat(sessionMoney);//先把传来的金额进行数值转换
let maxMoney = [];//存放大于场地费用最接近的数
let minMoney = [];//存放小于场地费用最接近的数
let couponsIndex=0;//获取最接近的key
for (let i = 0; i < couponsDataList.length; i++) {
let couponsItem = couponsDataList[i];
if(couponsItem.name=='不使用'){
continue;
}
couponsItem.max_price = parseFloat(couponsItem.max_price); //先进行浮点型数值转换
//如果等于就是最接近
if (couponsItem.max_price == sessionMoney) {
couponsIndex = i;
break;
}
if (couponsItem.max_price > sessionMoney) { //如果大于场地金额
console.log('价格相比大于:', couponsItem.max_price, sessionMoney);
maxMoney.push(parseFloat(couponsDataList[j].max_price));
} else if (couponsItem.max_price < sessionMoney) { //如果小于场地金额
console.log('价格相比小于:', couponsItem.max_price, sessionMoney);
minMoney.push(parseFloat(couponsDataList[j].max_price))
}
let jiejin = 0;
console.log('最接近优惠券的数:', '小于:', maxMoney, '大于:', minMoney);
//获取最近进的数
if (maxMoney.length > 0) {
jiejin = Math.min.apply(null, maxMoney);
} else if (minMoney.length > 0) {
jiejin = Math.max.apply(null, minMoney);
}
console.log('接近:', jiejin);
//用获取最接近的数对数组进行循环获取Key
if (0 != jiejin) {
for (let i = 0; i < couponsDataList.length; i++) {
if (jiejin == parseFloat(couponsDataList[i].max_price)) {
console.log('couponsDataList', couponsDataList);
couponsIndex = i;
}
}
}
return couponsIndex;//返回数组key
},
希望此文能帮到您,欢迎留言交流
如转载请加上原文链接