0

我的应用程序通过在每 15 个订单的收据/感谢页面上打印优惠券代码来奖励忠诚度。优惠券价值等于前 15 个订单之一的总价,随机抽取。

这工作了一段时间,但现在由于某种原因,每个新用户都会在他们的第一个订单上获得优惠券代码:

$count = dbFuncs::countRewardsProgress($_SESSION['user_id'])['count'];
$displayRewardsCode = dbFuncs::displayRewardsCode()['rewardsCode'];

        if ( $count > 0 ) {
            $remainder = $count % 15;
        }


        if($remainder == 0) {

            echo "Congratulations, You've earned a $$previousOrderValueRoulette coupon code! We thank you for your continued business.";
            echo "<br />";
            echo "<br />";
            echo 'Coupon code: ';
            echo $displayRewardsCode;

            dbFuncs::assignRewardsCode($previousOrderValueRoulette, $_SESSION['user_id'], $displayRewardsCode);

        } else {
            echo 'rewards progress: ';
            echo $count;
            echo '/15 orders completed';
        }

如何确保客户每 15 个订单只收到一张优惠券?

4

1 回答 1

0

因为 if$count为 0,$reminder没有初始化,所以在你的下一个条件下它等于 0。

要解决,将第二个条件更改为也检查$count大于 0

    if ( $count > 0 ) {
        $remainder = $count % 15;
    }


    if($count > 0 && $remainder == 0) {

        echo "Congratulations, You've earned a $$previousOrderValueRoulette coupon code! We thank you for your continued business.";
        echo "<br />";
        echo "<br />";
        echo 'Coupon code: ';
        echo $displayRewardsCode;

        dbFuncs::assignRewardsCode($previousOrderValueRoulette, $_SESSION['user_id'], $displayRewardsCode);

    } else {
        echo 'rewards progress: ';
        echo $count;
        echo '/15 orders completed';
    }
于 2018-03-20T10:00:06.880 回答