Files
YunNanProject/static/preschool_education.html

135 lines
4.2 KiB
HTML
Raw Normal View History

2025-09-10 16:14:35 +08:00
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
2025-09-10 16:27:38 +08:00
<title>云南省学前教育数据</title>
2025-09-10 16:14:35 +08:00
<link rel="stylesheet" href="css/style.css">
<script src="https://cdn.jsdelivr.net/npm/echarts@5.4.3/dist/echarts.min.js"></script>
<script src="js/jquery-3.7.1.min.js"></script>
2025-09-10 16:27:38 +08:00
<style>
.chart-controls {
margin: 20px 0;
text-align: center;
}
.btn-group {
display: inline-flex;
border-radius: 4px;
overflow: hidden;
box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}
.btn {
padding: 10px 20px;
border: none;
background: #f0f0f0;
cursor: pointer;
font-size: 14px;
transition: all 0.3s;
}
.btn.active {
background: #409eff;
color: white;
}
.btn:hover:not(.active) {
background: #e0e0e0;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 20px;
}
h1 {
text-align: center;
color: #333;
margin-bottom: 30px;
}
</style>
2025-09-10 16:14:35 +08:00
</head>
<body>
<div class="container">
2025-09-10 16:27:38 +08:00
<h1>云南省学前教育人数统计</h1>
<div class="chart-controls">
<div class="btn-group">
2025-09-10 16:39:30 +08:00
<button class="btn active" data-type="enroll">入园数总量</button>
2025-09-10 16:27:38 +08:00
<button class="btn" data-type="inschool">在园数总量</button>
</div>
</div>
<div id="preschoolChart" style="width: 100%; height: 500px;"></div>
2025-09-10 16:14:35 +08:00
<div id="message" class="message"></div>
</div>
<script>
// 初始化图表
var preschoolChart = echarts.init(document.getElementById('preschoolChart'));
2025-09-10 16:27:38 +08:00
var chartData = null;
2025-09-10 16:39:30 +08:00
var currentType = 'enroll';
2025-09-10 16:14:35 +08:00
// 显示加载状态
function showLoading() {
preschoolChart.showLoading();
}
// 隐藏加载状态
function hideLoading() {
preschoolChart.hideLoading();
}
// 显示错误信息
function showError(message) {
$('#message').text('错误: ' + message);
console.error(message);
}
2025-09-10 16:27:38 +08:00
// 渲染图表
function renderChart() {
if (!chartData) return;
var option = JSON.parse(JSON.stringify(chartData));
2025-09-10 16:39:30 +08:00
// 根据用户要求,现在显示所有系列数据,不需要过滤
2025-09-10 16:27:38 +08:00
preschoolChart.setOption(option);
}
2025-09-10 16:14:35 +08:00
// 加载学前教育数据
function loadPreschoolData() {
showLoading();
2025-09-10 20:18:01 +08:00
// 根据当前类型加载不同数据
var url = currentType === 'enroll' ?
'/bigscreen/school/preschool/chart' :
'/bigscreen/school/preschool/inschool/chart';
$.getJSON(url)
2025-09-10 16:14:35 +08:00
.done(function(data) {
2025-09-10 16:27:38 +08:00
chartData = data;
renderChart();
2025-09-10 16:14:35 +08:00
})
.fail(function(jqXHR, textStatus, errorThrown) {
showError(errorThrown || '获取数据失败,请检查接口是否正常');
})
.always(function() {
hideLoading();
});
}
2025-09-10 16:27:38 +08:00
// 按钮点击事件
2025-09-10 16:14:35 +08:00
$(document).ready(function() {
loadPreschoolData();
2025-09-10 16:27:38 +08:00
$('.btn').click(function() {
$('.btn').removeClass('active');
$(this).addClass('active');
currentType = $(this).data('type');
2025-09-10 20:18:01 +08:00
loadPreschoolData(); // 点击按钮后重新加载数据,而不是只渲染
2025-09-10 16:27:38 +08:00
});
// 窗口大小变化时调整图表
$(window).resize(function() {
preschoolChart.resize();
});
2025-09-10 16:14:35 +08:00
});
</script>
</body>
</html>