Javascript 用php计算月包(产品)价格

Javascript 用php计算月包(产品)价格,javascript,php,jquery,date,oop,Javascript,Php,Jquery,Date,Oop,我已经创建了一个电子商务网站,它将提供午餐和晚餐服务。我在这里提出问题是因为我知道这里有很多传奇人物可以帮助我。我在网站上添加了套餐/计划部分 1. Weekly 2. Monthly 这是订购产品的页面问题表单截图: 我可以轻松计算每周价格,就像如果产品价格为100,用户选择每周计划,他选择从周一到周六的天数(一周仅6天),那么我们可以轻松计算价格,使用6*100=600 但如何计算每月价格呢? 例如:如果用户选择了每月计划,并选择了一周中的6天,从周一到周六,或者任何他想选择的日子名


我已经创建了一个电子商务网站,它将提供午餐和晚餐服务。我在这里提出问题是因为我知道这里有很多传奇人物可以帮助我。我在网站上添加了套餐/计划部分

 1. Weekly
 2. Monthly
这是订购产品的页面问题表单截图:
我可以轻松计算每周价格,就像如果产品价格为100,用户选择每周计划,他选择从周一到周六的天数(一周仅6天),那么我们可以轻松计算价格,使用
6*100=600

但如何计算每月价格呢?
例如:如果用户选择了每月计划,并选择了一周中的6天,从周一到周六,或者任何他想选择的日子名称。然后他下订单。现在,

6 * 4 = 24 (6 days * 4 weeks)
24 * 100 = 2400 (days * product price)
但它只计算4周,而不是整个月。我要算一个月。如果我检查当前月份为30天,则
4(周)+2天
,如果当前月份为31天,则
4(周)+3天
。看起来很简单,但也很危险,因为如果+2天或+3天是用户在订购月包时未选中的那几天会怎么样。
这是我的代码:

<?php
    $pCartProducts = $pcart->getPlanCartProducts($userid);
?>

<tbody>
    <?php
        if($pCartProducts){
            $finalPrice = 0;
            while($pcPro = $pCartProducts->fetch_assoc()){
                $planName = $pcPro['plan_name'];
    ?>

    <tr>
        <td data-title="Plan">
            <?php echo $planName; ?>
        </td>
        <?php 

            $pro_price = $pcPro['pro_price'];
            $plan_days = $pcPro['plan_days']; // if user selected 6 days in a week
            $totaldays = $plan_days * 4; // 6 * 4 weeks = 24

            // Calculating current month days
            $month = date('m');
            $year = date('Y');
            $cal_days = cal_days_in_month(CAL_GREGORIAN, $month, $year);

            if($planName == 'Weekly'){

                $total_price = $pro_price * $plan_days;

            } elseif($planName == 'Monthly'){

                if($cal_days == '30'){
                     $final_tdays = $totaldays + 2; // + 2 days
                } elseif($cal_days == '31'){
                    $final_tdays = $totaldays + 3;  // + 3 days
                } elseif($cal_days == '29'){
                    $final_tdays = $totaldays + 1;  // + 1 day
                } elseif($cal_days == '28'){
                    $final_tdays = $totaldays;      // normal
                }

                $total_price = $final_tdays * $pro_price; // final days * product price

            }

        ?>
        <td data-title="Price">
            <span>Rs./<?php echo $total_price; ?></span>
        </td>
    </tr>
    <?php } } ?>
</tbody>

卢比/
其他屏幕截图:

有人能帮我计算一周中选定天数的月价格吗? 请帮助我

您有两个选择

选择1 考虑到这个月是固定的天数,比如30天或28天,然后继续你的工作,这很简单

选择2 一个月就是一个月,可以是28天,29天,30天或31天

好的,在这个方法中,我将计算客户使用您的服务的天数,然后乘以价格。我利用内置的
DateTime
类和它的friends
DateInterval
strotime
的功能,使这种方法适用于每周选项和每月选项,具体取决于他使用该服务的周数。它将循环抛出从开始日期算起的天数,如果在计划中选择了一周中的这一天,例如(星期日),它将对其进行计数

查看它,并根据您的需要进行更改,我试图对其进行评论,但如果有不明显的地方,请发表评论

<?php
$tz = new DateTimeZone("UTC");
//lets say he chosed the service on Monday and Tuesday and Wednesday
$days = "Monday ,Tuesday, Wednesday";// <-- change to user input
$planDays = translateWeekDaysToNumbers($days);
$planName = "Weekly";// <- change as user input

if($planName == 'Weekly'){
    $weekOrMonth = "week";
} else if ($planName == 'Monthly'){
    $weekOrMonth = "month";
} else {
    //TODO: throw error
}

$startString = "2019-02-01 00:00:00"; // <- change later to "now"
$startDate = new DateTime($startString, $tz);
$afterMonth = new DateTime("@" . strtotime("+1 $weekOrMonth", $startDate->format("U")));

$numberOfDays = $afterMonth->diff($startDate)->days;


$daysOfService = 0; // what we need to calculate

for($i = 0; $i<$numberOfDays + 1; $i++){
    $dateInterval = new DateInterval("P{$i}D");
    $startDate->add($dateInterval);
    if (in_array($startDate->format("w"), $planDays)) $daysOfService ++;
    $startDate->sub($dateInterval);//reset to first day
}

$pro_price = 100;// <--- change to your price from the DB
$totalPrice = $daysOfService * $pro_price;
echo $daysOfService . "\n";
echo $totalPrice . "\n";
exit;

/**
 * expects string like "Monday ,Tuesday, Wednesday"
   separated by comma. case is insensitive
 */
function translateWeekDaysToNumbers(string $days)
{
    
    //dont change the numbers as they are the given by ->format("w")
    $daysNumbers = [
        "sunday" => 0,
        "monday" => 1,
        "tuesday" => 2,
        "wednesday" => 3,
        "thursday" => 4,
        "friday" => 5,
        "saturday" => 6
    ];

    $days = explode(",", $days);
    $planDays = [];
    foreach($days as $day){
        $day = strtolower(trim($day));
        // if unexpected day name is provided
        // an undefined index warning will be shown
        // better than continue silently 
        $planDays[] = $daysNumbers[$day];
    }
    return $planDays;
}

您可以使用此代码更新您的每月状况

         elseif($planName == 'Monthly'){
        // suppose data are saved for on day(means client want order on these day) like Monday, Tuesday, Wednesday, Thursday 
        // it means 'Friday','Saturday','Sunday' is offday for him

        $weekDay = ['Monday', 'Tuesday', 'Wednesday', 'Thursday','Friday','Saturday','Sunday'];

        $onDay = 'Monday,Tuesday,Wednesday,Thursday';

        $onDayArr = explode(',', $onDay);
        $OffDayArr = [];
        foreach ($weekDay as $value) {
            if(!in_array($value, $onDayArr)) {
                $OffDayArr[] = $value;
            }
        }
        $count = 0;
        foreach ($OffDayArr as $$clientOffDay) {
            $str = 'first '.$clientOffDay.' '.$year.'-'.$month.'';
            $monthFisrtOffDay = date("j", strtotime($str));

            while($cal_days >= $monthFisrtOffDay) {
                $monthFisrtOffDay +=7;
                $count++;
            }
        }

        $total_price = $pro_price * ($cal_days-$count);
    }

如果你这样做的话,每月的价格将根据一年中的哪个月而有所不同。可能最好是制定每月价格
(52*$plan_days+1)/12
,但这并不完美,可能是价格会带来的,根据用户选择的天数,该价格将是额外的价格或可能是较低的价格,除非您想计算每年每个月的确切价格,您需要做出妥协。这样做有很多困难-这可能就是为什么一些服务会说一个月总是4周的原因。您有两种选择,两者都取决于您对月份的定义,1-将其定为固定天数(在我的网站上,我说月份=30天)或2-一个月就是一个月,这意味着如果今天是
2019-02-01
,他的服务将在
2019-03-01
结束,这意味着只有28/29天。我会看看是否可以在回答中给你举个例子,它只计算1周的价格?更改
$planName=“Weekly”
$planName=“每月”哦,我知道了,它来自DB,让我实现并选中此变量,将其设置为用户选择的“每周”或“每月”。我不知道为什么,但它给我的错误是
警告:in_array()希望参数2是数组,在第124行的E:\xampp\htdocs\zain\午餐\plan-cart.php中给出的字符串?假设,如果用户选择星期一到星期五,并将其存储在DB中,如:
Moday、星期二、星期三、星期四、星期五
,现在我们如何检查休息日?我更新了代码,请重新检查,并请让我知道您面临任何问题请检查我上面问题的最后两个屏幕截图。我添加了显示我如何存储天数和天数名称可以动态为$onday变量赋值,因为您保存的格式与我为$onday变量指定的列名称的格式相同