不败君

前端萌新&初级后端攻城狮

PHP开发节假日时间表

PHP开发节假日时间表

2021-03-18 18:32:59

围观(794)

无意中发现一个节假日的 API 接口:http://timor.tech/api/holiday/year

这个接口实现起来其实很简单,而且一年只需要维护一次,想要自己实现这个接口可参考博主之前写的这篇文章 PHP判断某个日期是否为工作日


使用这个接口可以更简单快速的写一个 “节假日时间表”,例如博主写的代码:

<?php
$yearPath = 'year.' . date('Y') . '.json';
$yearAPI = 'http://timor.tech/api/holiday/year';

if (!file_exists($yearPath)) {
	$yearJson = file_get_contents($yearAPI);
	file_put_contents($yearPath, $yearJson);
} else {
	$yearJson = file_get_contents($yearPath);
}

$lstYearData = json_decode($yearJson, true);

if ($lstYearData['code'] !== 0) {
	exit('发生致命问题');
}

$lstHoliday = [];

foreach ($lstYearData['holiday'] as $key => $row) {
	if (!$row['holiday']) {
		continue;
	}

	if (mb_strpos($row['name'], '初') !== false) {
		$row['name'] = '大年' . $row['name'];
	}

	if (!isset($lstHoliday[$row['name']])) {
		$lstHoliday[$row['name']] = [
			'name' => $row['name'],
			'wage' => $row['wage'],
			'date' => [
				$row['date']
			],
		];
	} else {
		$lstHoliday[$row['name']]['date'][] = $row['date'];
	}
}

$lstHoliday = array_values($lstHoliday);

function getNextHoliday()
{
	$nextHolidayPath = 'nextHoliday.json';

	$httpGetNextHoliday = function () use($nextHolidayPath) {
		$nextHolidayAPI = 'http://timor.tech/api/holiday/next';
		$nextHolidayJson = file_get_contents($nextHolidayAPI);
		$lstNextHoliday = json_decode($nextHolidayJson, true);

		if ($lstNextHoliday['code'] !== 0) {
			exit('发生致命问题');
		}

		file_put_contents($nextHolidayPath, json_encode([
			'date' => date('Ymd'),
			'data' => $nextHolidayJson
		]));

		return $lstNextHoliday;
	};

	if (!file_exists($nextHolidayPath)) {
		return $httpGetNextHoliday();
	}

	$nextHolidayJson = file_get_contents($nextHolidayPath);
	$lstNextHoliday = json_decode($nextHolidayJson, true);
	if ($lstNextHoliday['date'] !== date('Ymd')) {
		return $httpGetNextHoliday();
	}

	return json_decode($lstNextHoliday['data'], true);
}

$lstNextHoliday = getNextHoliday();
?>

<!DOCTYPE html>
<html>
<head>
	<title>节假日放假时间表 - 不败君</title>
	<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0">
	<meta name="viewport" content="initial-scale=1, width=device-width, maximum-scale=1, user-scalable=no">
	<link rel="stylesheet" href="https://www.bubaijun.com/layui/css/layui.css">
	<style type="text/css">
		.cool {
			background: #f2f2f2;
		}

		.name_type {
			margin: 20px 0px;
		}

		.title {
			text-align: center;
			border-bottom: 1px solid #ddd;
    		box-shadow: 0 0 7px 0 #ababab;
    		padding: 20px 0px;
		}

		.title a{
			color: #000;
			text-decoration: none;
		}
	</style>
</head>
<body>

	<div id="app" style="width: 95%; max-width: 500px; margin: 0 auto; text-align: center;">

		<div class="title">
			<a href="/demo/holiday"><?php echo date('Y')?>年节假日时间表</a>
		</div>

		<div class="layui-collapse" lay-accordion style="margin: 20px 0px;">
			<div class="layui-colla-item">

				<?php
					foreach ($lstHoliday as $key => $row) {
				?>

					<div class="layui-colla-content layui-show <?php if ($key % 2 == 1) {echo 'cool';}?>">
						<b><?php echo $row['name']?></b>
						<p>工资倍数:<?php echo $row['wage']?> 倍</p>
						<p style="margin-top: 20px;">放假时间</p>

						<?php
							foreach ($row['date'] as $date) {
						?>
							<p><?php echo $date?></p>
						<?php }?>
					</div>

				<?php }?>

			</div>
		</div>

		<div class="layui-collapse" lay-accordion style="margin: 20px 0px;">
			<div class="layui-colla-item">
				<div class="layui-colla-content layui-show cool">
					<p>下一个节假日</p>
					<b><?php echo $lstNextHoliday['holiday']['name']?></b>
					<p>工资倍数: <?php echo $lstNextHoliday['holiday']['wage']?> 倍</p>
					<p>放假起始日:<?php echo $lstNextHoliday['holiday']['date']?></p>
				</div>
			</div>
		</div>

	</div>

	<script src="https://www.bubaijun.com/layui/layui.js"></script>
</body>
</html>

本文最后实现的效果: 节假日时间表

如果有兴趣还可以根据接口返回的数据,计算下一个节假日。

另外,博主之前还写过类似的文章:

PHP开发计算下一个节假日时间并倒计时

本文地址 : www.bubaijun.com/page.php?id=232

版权声明 : 未经允许禁止转载!

评论:我要评论
发布评论:
Copyright © 不败君 粤ICP备18102917号-1

不败君

首 页 作 品 微 语