- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了电子商务网站,即将提供午餐和晚餐服务。我在这里提出问题/问题是因为我知道这里有很多可以帮助我的传奇人物。我在网站上添加了套餐/计划部分。
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 (weeks) + 2 days
如果当前月份是 31 天,则 4 (weeks) + 3 days
.看起来很简单而且完成了,但它也很危险,因为如果那 + 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>
有人可以帮我计算一周中选定几天的月度价格吗?请帮帮我
最佳答案
你有两个选择
考虑这个月是固定的天数,例如 30 或 28,然后继续您的工作,就这么简单。
一个月就是一个月,可以是 28 天、29、30 或 31。
好的,在这种方法中,我将计算客户使用您的服务的天数,然后乘以价格。我使用内置 DateTime
类及其 friend 的强大功能,根据他将在一周中的哪几天使用该服务,使这种方法适用于每周选项和每月选项DateInterval
和 strtotime
。它会循环抛出从开始日期算起的天数,如果在计划中选择了一周中的这一天,例如(星期日),它将计算在内。
检查一下,并根据需要进行更改,我尝试对其进行评论,但是如果有什么不明显的地方,请发表评论。
<?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;
}
关于javascript - 在php中计算每月包(产品)价格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57932743/
我需要一些帮助。 我希望“总计”由“数量*价格=总计”计算(到目前为止没问题)。问题是我还需要通过“总/价格=数量”来计算“数量”,即如果一个字段发生更改,另一个字段也会自动更改。 我做了一个非常简单
我试图将每件商品的数量和价格相乘来计算总数,但我的警报中出现错误。 $.each(data.items, function(index, d){ var calcultest = d.pric
我想获得格式化的价格但没有货币符号,我只想使用 magento 的标准功能! $product->getFinalPrice(); => 19.9900 Mage::helper('core')->f
我正在尝试获取特定月份和年份中所有父类别的总价格。父类别是 parent_id == 0 的任何类别。我的查询如下所示: SELECT ROUND(SUM(od.total_price)) a
请帮我摆脱我的头痛..提前我为我的糟糕语言道歉,无论是英语还是mysql。希望有人能理解这个问题..:) 我有一个数据库,任何人都可以记录各个商店中各种产品的价格。以下查询是一个半理论示例,可能根本不
下面是我需要在数据库中设计的示例: 会有一个价格选项,如果有的话,会有一个特价选项,然后我想知道如果我希望其中一个选项是“免费”的,我该怎么做。 另请参阅根据所在国家/地区会有不同的货币。这是我的想法
商品价格格式 999,99 999 - 1 ..4 digits , - comma sign marks decimal point 99 - 2 digits after price Postg
我有这个表 stk +---------+--------------+ | Field | Type | +---------+--------------+ | id
是否有一个简单的格式化程序可以将我的字符串格式化为价格? 所以我的字符串是:300000 我想用空格来“300 000” or 1000000 "1 000 000" 张国荣 最佳答案 这样做: St
我想知道是否可以使用不依赖于 Excel 应用程序本地化(欧盟/美国)的 Excel 公式来自定义数字格式? 例如,我的值为 1291660。 然后使用公式=TEXT(A1;"# ##0,00") .
这是我的代码,对于价格 slider : $("#price-slider").ionRangeSlider({ min: 130, max: 575, onChange :
用户可以使用价格创建一个新实体。价格可以使用不同的货币(EUR,USD ...),因此我们可以乘以(price * convert_rate)得到实际价格。 我想做的是根据价格过滤记录,具体取决于前端
我正在尝试隐藏小数位在类型输入字段上,例如 数字从0.00开始 因此,输入字段中的第一个位置将为 0.00 我输入的1比它应该变成0.01 我输入的2比它应该变成0.12 比 0 所以它应该变成 1.
$res=mysql_query($qry); while($row= mysql_fetch_array($res)) { echo "".$row['Food_Name']." ".$row['P
我们正在为我们的新项目寻找信用卡网关。那里一片困惑,所有人都想把你切成碎片。每次我与他们交谈时,他们都有不同的费率,每次更新报价时,他们都会更改一些价格。 我们正在使用 .net、C#、asp.net
我已经创建了一个 jQuery 价格 slider ,但我不确定如何让过滤区域以实际价格范围开始?目前它有“$[object Object] - $[object Object]”,而我希望它有“$2
我已经创建了 jquery 价格 slider ,但我不确定如何过滤我的结果,以便在滑动时您只能看到具有该值范围内的产品。 HTML: Price range:
我有一个页面,其中有一个表格,我们可以在其中选择一个产品,输入它的数量和价格,然后应在最后一列中计算金额,并应添加新行以输入更多产品,直到我们完成为止。
我创建了电子商务网站,即将提供午餐和晚餐服务。我在这里提出问题/问题是因为我知道这里有很多可以帮助我的传奇人物。我在网站上添加了套餐/计划部分。 1. Weekly 2. Monthly 以下是订
我的网站需要一个简单的 jQuery 价格 slider 。从 0 英镑到 1000 英镑不等。 假设浏览器将 slider 设置为 100 英镑(例如),然后我需要一个立即购买按钮,该按钮将 sli
我是一名优秀的程序员,十分优秀!