
本教程将指导您如何使用html、css和javascript构建一个交互式网页,实现通过下拉菜单选择不同时区,并实时显示该时区的当前时间。同时,页面将根据选择动态展示或隐藏与该时区相关的详细信息表格,确保用户界面的响应性和信息的直观呈现。
在现代Web应用中,为用户提供个性化的时间显示和相关信息是常见的需求。本教程将详细介绍如何通过一个简洁的下拉菜单,不仅能实时更新所选时区的当前时间,还能动态切换显示与该时区相关的详细地域信息表格。我们将利用HTML构建页面结构,CSS进行样式美化,并运用JavaScript实现核心的动态交互逻辑。
为了实现上述功能,我们需要精心设计HTML结构、应用CSS样式,并编写JavaScript逻辑来处理用户交互和时间更新。
页面的HTML结构主要包含用于显示时间的<span>元素、一个用于选择时区的<select>下拉菜单,以及一系列根据时区选择而显示/隐藏的<table>元素。
<span id="ct"></span><br>
<span id="ct2"></span><br>
<select name="tz"></select>
<p>Select Timezone above</p>
<br><br>
<!-- 以下是根据不同时区显示的信息表格,id从t1到t7 -->
<table id="t1" border="1">
<tr>
<th>Country</th>
<th>Capital</th>
</tr>
<tr>
<td>Philippines</td>
<td>Manila</td>
</tr>
</table>
<table id="t2" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> Ontario</td>
<td> Eastern</td>
<td> Toronto</td>
<td> Ottawa, Mississauga, <br>Hamilton, Kitchener, <br>London, Oshawa, <br>Windsor, Barrie, <br>Guelph, Kingston, <br>Sudbury, Thunder Bay, <br>Etobicoke</td>
</tr>
<tr>
<td> Quebec</td>
<td> Eastern</td>
<td> Quebec City</td>
<td> Montreal, Sherbrooke, <br>Trois-Rivières, Chicoutimi, <br>Châteauguay, Granby</td>
</tr>
<tr>
<td> Nunavut</td>
<td> Eastern</td>
<td> Iqaluit</td>
<td> Cambridge Bay, Rankin Inlet</td>
</tr>
</table>
<table id="t3" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> Nova Scotia</td>
<td> Atlantic</td>
<td> Halifax</td>
<td> Cape Breton, Sydney, <br>Truro, Dartmouth </td>
</tr>
<tr>
<td> New Brunswick</td>
<td> Atlantic</td>
<td> Fredericton</td>
<td> Moncton, Saint John, <br>Fredericton</td>
</tr>
<tr>
<td> Prince Edward Island</td>
<td> Atlantic</td>
<td> Charlottetown</td>
<td> Summerside, Stratford</td>
</tr>
</table>
<table id="t4" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> Manitoba</td>
<td> Central</td>
<td> Winnipeg</td>
<td> Brandon, Churchill, <br>Steinbach, Winkler, <br>Portage La Prairie, Thompson</td>
</tr>
</table>
<table id="t5" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> British Columbia</td>
<td> Pacific</td>
<td> Victoria</td>
<td> Vancouver, Surrey, <br>Burnaby, Richmond, <br>Abbotsford, Coquitlam, <br>Kelowna, Nanaimo, <br>Kamloops</td>
</tr>
<tr>
<td> Yukon</td>
<td> Pacific</td>
<td> Whitehorse</td>
<td> Cambridge Bay, Rankin Inlet</td>
</tr>
</table>
<table id="t6" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> Saskatchewan</td>
<td> Mountain</td>
<td> Regina</td>
<td> Saskatoon, Moose Jaw, <br>Swift Current, Yorkton</td>
</tr>
<tr>
<td> Alberta</td>
<td> Mountain</td>
<td> Edmonton</td>
<td> Calgary, Red Deer, <br>Lethbridge, Airdrie, <br>Medicine Hat, Grande Prairie, <br>Banff</td>
</tr>
<tr>
<td> Northwest Territories</td>
<td> Mountain</td>
<td> Yellowknife</td>
<td> Inuvik</td>
</tr>
</table>
<table id="t7" border="1">
<tr>
<th> Province/Territory</th>
<th> Time Zone</th>
<th> Capital</th>
<th> Other Cities</th>
</tr>
<tr>
<td> Newfoundland and Labrador</td>
<td> Newfoundland</td>
<td> St. John's</td>
<td> Corner Brook, Grand Falls-Windsor, <br>Gander</td>
</tr>
</table>在上述HTML中:
立即学习“Java免费学习笔记(深入)”;
CSS主要用于美化页面元素,如字体、大小以及下拉菜单和表格的边框与对齐方式。
#ct {
font-family: arial;
font-size: 15px;
}
p {
font-family: arial;
font-size: 15px;
}
select {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
padding: 1px;
font-size: 15px;
}
td,
th {
text-align: left;
padding: 5px;
font-family: arial;
font-size: 15px;
}
th {
text-align: center;
padding: 5px;
font-family: arial;
font-size: 15px;
}这些样式确保了页面元素具有良好的可读性和统一的视觉风格。select元素的appearance: none属性用于移除浏览器默认的下拉箭头样式,以便更好地进行自定义。
JavaScript是实现所有动态行为的核心。它负责填充下拉菜单、实时更新时间、以及根据用户选择切换表格的显示状态。
// 隐藏ct2元素,因为它可能在某些情况下不需要立即显示
var link = document.getElementById('ct2');
link.style.visibility = 'hidden';
// 获取下拉菜单元素
const sel = document.querySelector("[name=tz]");
// 定义一个函数来显示实时时区时间
const disp_TZ = () => {
const tz = sel.value; // 获取当前选中的时区值
// 使用toLocaleString获取指定时区的完整时间信息
let str = new Date().toLocaleString("en-US", {
timeZone: tz,
timeZoneName: "short"
});
document.getElementById('ct').innerHTML = str + " ,<br> " + tz;
// 计算并显示简化的时分秒
const dt2 = new Date();
const str2 = new Date(dt2.toLocaleString('en-US', {
timeZone: tz
}));
const diff = dt2.getTime() - str2.getTime();
const dt3 = new Date(dt2.getTime() - diff);
const hour = dt3.getHours();
const minute = dt3.getMinutes();
const seconds = dt3.getSeconds();
const str3 = `${hour}:${minute}:${seconds}`; // 模板字符串格式化
document.getElementById('ct2').innerHTML = str3;
display_c(); // 继续调用以实现实时更新
};
// 定义可供选择的时区列表
var my_timezones = [
'None Selected ',
'Asia/Manila',
'Canada/Eastern',
'Canada/Atlantic',
'Canada/Central',
'Canada/Pacific',
'Canada/Mountain',
'Canada/Newfoundland'
];
// 获取所有以't'开头的表格元素
const tables = document.querySelectorAll("table[id^=t]");
// 定义一个函数来切换表格的显示状态
const toggleStyle = () => {
const idx = sel.selectedIndex; // 获取下拉菜单当前选中项的索引
// 遍历所有表格,根据索引决定是否显示
tables.forEach(table => table.hidden = (table.id !== `t${idx}`));
};
// 动态填充下拉菜单选项
my_timezones.forEach(tz => {
let opt = document.createElement('option');
opt.text = tz;
opt.value = tz;
sel.appendChild(opt);
});
// 定义一个函数来每秒刷新时间显示
const display_c = () => {
const refresh = 1000; // 1秒刷新一次
setTimeout(disp_TZ, refresh); // 使用setTimeout递归调用disp_TZ
};
// 为下拉菜单添加事件监听器
sel.addEventListener("change", disp_TZ); // 选项改变时更新时间
sel.addEventListener("change", toggleStyle); // 选项改变时切换表格显示
// 初始化页面状态:首次加载时隐藏所有表格,并显示初始时间
toggleStyle();
disp_TZ(); // 首次加载时调用一次以显示时间JavaScript 逻辑详解:
DOM 元素获取与初始化:
动态填充下拉菜单:
实时时间显示函数 (disp_TZ):
内容切换函数 (toggleStyle):
实时刷新机制 (display_c):
事件监听与初始状态:
通过本教程,我们学习了如何结合HTML、CSS和JavaScript,构建一个功能强大的时区选择器。它不仅能实时显示所选时区的当前时间,还能根据用户的选择动态展示或隐藏相关的地域信息表格。这种模式在需要根据用户输入动态更新内容和布局的Web应用中非常常见。通过理解和实践这些核心概念,您可以进一步扩展功能,例如添加更多时区、自定义时间显示格式,或者集成其他动态数据。
以上就是JavaScript实现下拉选择时区并实时显示时间及相关信息的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号