Project Icon

tzdb

自动更新的IANA时区数据JavaScript库

tzdb是一个自动更新的JavaScript库,简化IANA时区数据处理。它提供替代名称、主要城市和时区偏移信息,适用于构建时区选择功能。该库包含多个API,支持时区分组和UTC选项,便于开发者实现灵活的时区管理。

tzdb GitHub 许可证 测试 npm 版本 压缩后大小

这是一个列表和 npm 包,包含:

  • "简化"的 IANA 时区,使用如 Pacific Time 而非 America/Los_Angeles 的替代名称,以及每个时区的主要城市。
  • 所有现有的原始 IANA 时区名称
  • "原始"偏移量以及当前时间偏移量
  • 还包括已弃用的时区名称以保持兼容性

数据和 npm 包会在 https://www.geonames.org/ 发生变化时自动更新,该网站是根据 IANA 数据库生成的。

这在构建应用程序的时区选择菜单时非常有用。

NPM 包

安装:

npm add @vvo/tzdb

使用:

import { getTimeZones, rawTimeZones, timeZonesNames, abbreviations } from "@vvo/tzdb";

API

getTimeZones()

const timeZones = getTimeZones();

// 你也可以提供一个可选参数来在结果中包含 UTC。
// 这会添加一个名为 "UTC" 且固定偏移量为 0 的时区。
const timeZonesWithUtc = getTimeZones({ includeUtc: true });

此方法返回一个时区对象数组:

[
  // ...
  {
    name: "America/Los_Angeles",
    alternativeName: "Pacific Time",
    group: ["America/Los_Angeles"],
    continentCode: "NA",
    continentName: "North America",
    countryName: "United States",
    countryCode: "US",
    mainCities: ["Los Angeles", "San Diego", "San Jose", "San Francisco"],
    rawOffsetInMinutes: -480,
    abbreviation: "PST",
    rawFormat: "-08:00 Pacific Time - Los Angeles, San Diego, San Jose, San Francisco",
    currentTimeOffsetInMinutes: -420, // "当前"时区偏移量,这就是为什么 getTimeZones() 是一个方法而不仅仅是一个对象:它在运行时工作
    currentTimeFormat: "-07:00 Pacific Time - Los Angeles, San Diego",
  },
  // ...
];

在适当的情况下,时区会被分组。分组规则如下:

  • 如果时区在同一国家
  • 如果夏令时或夏季时间偏移量相同
  • 如果非夏令时、非夏季时间偏移量相同
  • 那么我们就将这些时区分组
  • "主要"时区名称(name 属性)始终是人口最多的城市的时区

以下是一个分组示例:

{
  name: "America/Dawson_Creek",
  alternativeName: "Mountain Time",
  group: ["America/Creston", "America/Dawson_Creek", "America/Fort_Nelson"],
  continentCode: "NA",
  continentName: "North America",
  countryName: "Canada",
  countryCode: "CA",
  mainCities: ["Fort St. John", "Creston", "Fort Nelson"],
  rawOffsetInMinutes: -420,
  abbreviation: "MST",
  rawFormat: "-07:00 Mountain Time - Fort St. John, Creston, Fort Nelson",
  currentTimeOffsetInMinutes: -420,
  currentTimeFormat: "-07:00 Mountain Time - Fort St. John, Creston"
}

rawTimeZones

这是一个不包含当前时间信息的时区对象数组:

[
  // ...
  {
    name: "America/Los_Angeles",
    alternativeName: "Pacific Time",
    group: ["America/Los_Angeles"],
    continentCode: "NA",
    continentName: "North America",
    countryName: "United States",
    countryCode: "US",
    mainCities: ["Los Angeles", "San Diego", "San Jose", "San Francisco"],
    rawOffsetInMinutes: -480,
    abbreviation: "PST",
    rawFormat: "-08:00 Pacific Time - Los Angeles, San Diego, San Jose, San Francisco",
  },
  // ...
];

timeZonesNames

这是一个时区名称数组:

[
  // ...
  "America/Juneau",
  "America/Kentucky/Louisville",
  "America/Kentucky/Monticello",
  "America/Kralendijk",
  "America/La_Paz",
  "America/Lima",
  "America/Los_Angeles",
  "America/Lower_Princes",
  "America/Maceio",
  "America/Managua",
  "America/Manaus",
  "America/Marigot",
  "America/Martinique",
  "America/Matamoros",
  // ...
];

abbreviations

这是一个将时区缩写映射到其全称的对象:

{
  // ...
  "Australian Central Daylight Time": "ACDT",
  "Australian Central Standard Time": "ACST",
  "Australian Central Time": "ACT",
  "Australian Central Western Standard Time": "ACWST",
  "Australian Eastern Daylight Time": "AEDT",
  "Australian Eastern Standard Time": "AEST",
  "Australian Eastern Time": "AET",
  "Australian Western Daylight Time": "AWDT",
  "Australian Western Standard Time": "AWST",
  "Azerbaijan Summer Time": "AZST",
  "Azerbaijan Time": "AZT",
  "Azores Summer Time": "AZOST",
  "Azores Time": "AZOT",
  "Bangladesh Standard Time": "BST",
  "Bhutan Time": "BTT",
  "Bolivia Time": "BOT",
  // ...
};

注意: 虽然缩写查找起来很方便,但它们可能会产生误导。例如:CST 可以指中央标准时间(UTC -06:00)、中国标准时间(UTC +06:00)或古巴标准时间(UTC -05:00)。而且缩写的全称并不直接映射到 rawTimeZonesgetTimeZones() 返回的时区对象中的任何属性。

注意事项

  • 当发生分组时,我们会提供两个城市,按人口排序
  • 我们提供替代名称("America/Los_Angeles" 的 "Pacific Time"),并从中删除 "Standard"、"Daylight" 或 "Summer"
  • 如果你使用这个来构建时区选择器并保存到数据库,那么:
    • 确保在数据库中保存 name 属性(America/Los_Angeles
    • 当显示带有数据库默认值的选择器时,选择匹配的时区名称,或者如果时区名称是组的一部分。例如:
const value = timeZones.find((timeZone) => {
  return dbData.timeZone === timeZone.name || timeZone.group.includes(dbData.timeZone);
});
项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号