JavaScript:获取从周一到周日的本地化星期短名称序列

javascript:获取从周一到周日的本地化星期短名称序列

本教程详细介绍了如何使用JavaScript的`Intl.DateTimeFormat` API,以指定区域设置获取从周一到周日的本地化星期短名称序列。通过动态计算日期偏移量并利用`formatToParts`方法,确保无论当前日期如何,都能准确生成并提取符合国际化标准的星期名称列表,为多语言应用开发提供可靠方案。

在构建全球化的Web应用程序时,经常需要根据用户的语言环境显示本地化的日期和时间信息。其中一个常见的需求是获取一周中每一天的本地化短名称,并且通常要求从周一开始排列。JavaScript的Intl.DateTimeFormat API为解决此类国际化问题提供了强大而灵活的工具

理解 Intl.DateTimeFormat API

Intl.DateTimeFormat 是ECMAScript国际化API的一部分,它允许应用程序格式化日期和时间,使其符合特定语言环境(locale)的约定。它的构造函数接受两个参数:locales(一个语言环境字符串或数组)和 options(一个配置对象)。

要获取星期的名称,我们主要关注options对象中的weekday属性。该属性可以接受以下值:

立即学习“Java免费学习笔记(深入)”;

‘long’:完整名称(例如 “Monday”)。’short’:短名称(例如 “Mon”)。’narrow’:最窄名称(例如 “M”),可能与’short’相同,具体取决于语言环境。

实现从周一到周日的本地化星期短名称

为了获取从周一到周日(而不是从当前日期所在星期开始)的本地化星期短名称列表,我们需要一个策略来生成代表一周中每一天的日期对象,然后对其进行格式化。

以下是实现这一目标的详细步骤和代码示例:

定义目标语言环境和格式化选项:首先确定需要获取哪种语言环境的星期名称,并指定weekday: ‘short’。创建 Intl.DateTimeFormat 实例:使用定义的语言环境和选项创建一个格式化器。遍历一周:通过循环从周一(索引为1)到周日(索引为7),为每一天生成一个日期。计算日期偏移量:这是关键步骤。我们需要一个方法,无论当前日期是哪一天,都能可靠地生成代表一周中特定日期的Date对象。我们可以通过计算当前日期与目标星期几之间的天数差来实现。格式化并提取名称:使用格式化器的formatToParts()方法来格式化生成的日期,并从中提取weekday类型的值。formatToParts()返回一个对象数组,每个对象描述日期时间字符串的一个组成部分,这比直接使用format()更健壮,因为它允许我们精确地找到并提取星期名称。

示例代码

/** * 获取指定语言环境从周一到周日的本地化星期短名称列表。 * @param {string} locale - 目标语言环境字符串,例如 "en-US", "fr-FR", "zh-CN"。 * @returns {string[]} 包含从周一到周日星期短名称的数组。 */function getLocalizedShortWeekdaysFromMonday(locale) {  const shortNames = [];  // 创建一个日期格式化器,用于获取星期的短名称  const formatter = new Intl.DateTimeFormat(locale, {    weekday: 'short'  });  // 获取当前日期,作为计算其他日期偏移量的基准  const today = new Date();  const currentDayOfWeek = today.getDay(); // 0代表周日,1代表周一...6代表周六  // 定义周一的数字表示(在Date对象中是1)  const MONDAY_INDEX = 1;  // 循环7次,为一周中的每一天生成日期并提取名称  for (let i = 0; i  part.type === 'weekday').value;    shortNames.push(shortName);  }  return shortNames;}// 示例用法console.log("英语 (美国) 周一到周日:", getLocalizedShortWeekdaysFromMonday("en-US"));// 输出示例: 英语 (美国) 周一到周日: [ 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun' ]console.log("法语 (法国) 周一到周日:", getLocalizedShortWeekdaysFromMonday("fr-FR"));// 输出示例: 法语 (法国) 周一到周日: [ 'lun.', 'mar.', 'mer.', 'jeu.', 'ven.', 'sam.', 'dim.' ]console.log("中文 (中国) 周一到周日:", getLocalizedShortWeekdaysFromMonday("zh-CN"));// 输出示例: 中文 (中国) 周一到周日: [ '周一', '周二', '周三', '周四', '周五', '周六', '周日' ]console.log("德语 (德国) 周一到周日:", getLocalizedShortWeekdaysFromMonday("de-DE"));// 输出示例: 德语 (德国) 周一到周日: [ 'Mo.', 'Di.', 'Mi.', 'Do.', 'Fr.', 'Sa.', 'So.' ]

代码解析

formatter = new Intl.DateTimeFormat(locale, { weekday: ‘short’ });: 初始化一个格式化器,指定了语言环境和只提取星期短名称的选项。today = new Date();: 获取当前日期。虽然我们不直接使用today的星期几,但它是我们计算其他日期偏移量的参考点。currentDayOfWeek = today.getDay();: getDay()方法返回一个0(周日)到6(周六)的整数。for (let i = 0; i : 循环7次,代表一周的7天。date = new Date(today);: 为每次迭代创建一个新的Date对象,以避免在循环中修改原始的today对象。targetDayIndex = (MONDAY_INDEX + i) % 7;: 计算当前循环迭代对应的星期几的索引。MONDAY_INDEX是1,i从0到6。例如:i=0: (1+0)%7 = 1 (周一)i=1: (1+1)%7 = 2 (周二)…i=6: (1+6)%7 = 0 (周日)daysToAdd = (targetDayIndex – currentDayOfWeek + 7) % 7;: 这是计算日期偏移量的核心逻辑。(targetDayIndex – currentDayOfWeek):计算目标星期几与当前星期几之间的天数差。结果可能是负数。+ 7:确保结果为正数,即使天数差是负的。% 7:取模操作,将结果限制在0到6之间,表示从当前日期到目标星期几需要增加的天数。date.setDate(today.getDate() + daysToAdd);: 通过增加计算出的天数来调整date对象,使其指向目标星期几。formatter.formatToParts(date): 格式化当前date对象,并返回一个包含日期各部分的对象数组。.find(part => part.type === ‘weekday’).value: 从返回的数组中找到type为’weekday’的部分,并提取其value,这就是我们需要的本地化星期短名称。

注意事项

浏览器兼容性:Intl.DateTimeFormat API在现代浏览器和Node.js环境中得到了广泛支持。对于旧版浏览器,可能需要引入Polyfill(例如Intl.js)。语言环境字符串:确保使用的语言环境字符串是有效的BCP 47语言标签(例如 “en-US”, “fr-FR”, “zh-CN”)。不正确的标签可能导致回退到默认语言环境或抛出错误。weekday 选项:根据需求选择’short’、’long’或’narrow’。性能考量:对于需要频繁获取大量本地化日期信息的场景,建议缓存Intl.DateTimeFormat实例,而不是每次都创建新的实例。

总结

通过利用JavaScript的Intl.DateTimeFormat API并结合巧妙的日期偏移量计算,我们可以轻松地获取到从周一到周日、符合特定语言环境的本地化星期短名称列表。这种方法不仅提供了高度的灵活性和准确性,而且是构建多语言和国际化应用程序的推荐实践。掌握这一技巧,将使您的Web应用在处理日期和时间显示时更加健壮和用户友好。

以上就是JavaScript:获取从周一到周日的本地化星期短名称序列的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1537904.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
React应用中WebAssembly模块的跨框架共享与统一访问
上一篇 2025年12月21日 04:32:26
js的math对象random()方法
下一篇 2025年12月21日 04:32:39

相关推荐

  • 使用JS动态生成HTML时如何管理状态_使用JS动态生成HTML时如何管理状态策略

    答案:管理JavaScript动态生成HTML的状态需以数据驱动UI。1. 使用单一数据源确保状态集中,如将用户信息存于对象中,更新时先改数据再重新渲染;2. 封装状态与逻辑,用类组织数据和方法,调用方法后自动刷新视图;3. 借鉴响应式模式,通过Proxy监听状态变化并自动更新界面;4. 避免频繁直…

    2026年5月10日
    000
  • 以太坊和比特币的区别_主要差异在哪里

    比特币是去中心化电子现金,专注价值存储与转移;以太坊是可编程平台,支持智能合约与去中心化应用,二者在定位、技术与生态上根本不同。 以太坊和比特币:不仅仅是数字资产的差异 当人们谈论加密世界时,比特币和以太坊是两个无法绕开的名字。虽然它们常常被并列提及,但实际上,两者在设计哲学、核心功能和未来愿景上存…

    2026年5月10日
    000
  • Web开发教程:如何在HTML容器中正确调整图片大小

    Web开发教程:如何在HTML容器中正确调整图片大小Web开发教程:如何在HTML容器中正确调整图片大小Web开发教程:如何在HTML容器中正确调整图片大小Web开发教程:如何在HTML容器中正确调整图片大小

    本教程旨在解决HTML中图片无法按预期在容器内缩放的问题。当图片尺寸超出其父容器时,通常需要通过CSS设置图片的width: 100%,使其自适应父容器的宽度,从而避免溢出并实现响应式布局。文章将详细阐述这一核心解决方案,并提供代码示例,帮助开发者掌握图片在Web页面中的正确缩放技巧。 理解图片在H…

    2026年5月10日 用户投稿
    000
  • HTML如何添加字体图标?iconfont怎么引入?

    字体图标不显示最常见的原因是路径错误,需检查iconfont.css中字体文件的url路径是否与实际存放位置一致,并通过浏览器开发者工具的network面板确认字体文件是否404;2. 确保html元素同时包含基础类名iconfont和具体图标类名如icon-home,类名缺失会导致图标无法渲染;3…

    2026年5月10日
    000
  • Golang指针与闭包变量捕获区别分析

    指针保存变量内存地址,可间接读写值;2. 闭包捕获外部变量本身而非值,循环中goroutine易误共享变量导致数据竞争。 在Go语言中,指针和闭包变量捕获是两个容易混淆的概念,尤其在循环中使用goroutine或匿名函数时。它们的行为差异直接影响程序的正确性,理解其机制对编写安全、可预测的代码至关重…

    2026年5月10日
    000
  • 非关联元素悬停交互:使用JavaScript动态调整DIV亮度

    本文详细介绍了如何通过javascript实现对非关联html元素进行悬停交互效果,具体演示了当鼠标悬停在一个`div`上时,如何动态改变另一个`div`的亮度。教程涵盖了html结构、javascript事件监听与css `filter`属性的应用,并提供了完整的代码示例、平滑过渡效果的实现以及最…

    2026年5月10日
    000
  • JSON文件转换为二进制格式后,体积一定会缩小吗?

    json 文件转换为二进制格式后,体积会缩小吗?这取决于具体情况。 JSON (JavaScript Object Notation) 是一种常用的数据交换格式,易于人类阅读和编写。但它也可能比较冗余,尤其是在处理大量数据时。 将 JSON 转换为二进制格式,通常可以减少文件大小,因为二进制格式更紧…

    2026年5月10日
    000
  • BRC-20和Ordinals协议是什么?比特币生态的新革命还是昙花一现

    BRC-20代币标准是技术创新也是短暂热潮:它基于Ordinals协议为“聪”编号并铭刻数据,实现比特币网络上的资产发行;其核心机制是通过JSON文本铭刻模拟代币操作,不依赖智能合约而依赖链下索引器,引发去中心化争议;尽管拓展了比特币功能、提升矿工收入、体现公平发行精神,但也导致网络拥堵、费用高涨、…

    2026年5月10日
    000
  • Python网络爬虫:应对动态CSS类名选择的策略

    在Python网络爬虫中,面对现代网站动态生成的随机CSS类名(如media-story-card__body__3tRWy)是常见挑战。本文将详细介绍如何利用CSS属性选择器,特别是“以…开头”的选择器([attribute^=”value”]),来有效定位这些…

    2026年5月10日
    100
  • 如何用Golang实现指针安全访问_Golang 指针安全操作实践

    指针安全需确保初始化后使用,避免nil解引用,如用new()或&初始化;返回局部变量地址时依赖逃逸分析;并发访问时用sync.Mutex或atomic保护共享数据;通过接口封装降低暴露风险,始终假设指针可能为nil并协调共享访问。 在 Go 语言中,指针提供了对内存的直接访问能力,提升了性能…

    2026年5月10日
    000
  • 获取 Android WebView 新窗口 URL 的正确方法

    本文档旨在解决 Android WebView 中 `onCreateWindow` 方法无法直接获取 `window.open()` 打开的新窗口 URL 的问题。通过重写 `WebViewClient` 的 `shouldOverrideUrlLoading` 方法,并结合 `WebChrome…

    2026年5月10日
    000
  • FastAPI如何高效实现类似Django-filter的大于小于范围筛选?

    FastAPI高效实现数据范围筛选,媲美Django-filter Django的django-filter库提供便捷的数据库范围筛选功能。本文将探讨如何在FastAPI中高效实现类似功能,无需依赖额外库。 FastAPI本身不包含类似django-filter的工具,但我们可以巧妙地利用SQLAl…

    2026年5月10日
    000
  • Go语言:不使用 flags 包获取命令行参数的实践

    本文将深入探讨在Go语言中,如何在不依赖标准库flags包的情况下,直接获取和处理命令行参数。通过使用os.Args,开发者可以访问程序启动时传入的原始参数切片,这对于实现自定义的、符合特定规范(如GNU风格)的命令行解析器至关重要。文章将提供详细的代码示例,并解析os.Args的结构与应用场景,帮…

    2026年5月10日
    000
  • 解决 Carbon::parse 无法解析复杂数据结构中的日期时间字符串问题

    本教程详细阐述了在使用 carbon 解析日期时间时,如何处理来自数据库查询结果或 json 字符串等复杂数据结构中嵌套的 `created_at` 字段。文章将通过示例代码演示如何正确提取日期时间字符串,并将其转换为 carbon 实例,从而避免常见的解析错误,并顺利进行日期时间操作,如添加天数和…

    2026年5月10日
    000
  • 外部CSS怎么链接到HTML页面_外部CSS链接到HTML页面的详细说明

    使用外部CSS文件可提升代码维护性与复用性。一、通过link标签在HTML的head中引入CSS,设置rel=”stylesheet”、href指向文件路径,推荐使用。二、利用@import指令导入CSS,可在style标签或CSS文件中使用,但会延迟加载,影响性能。三、通过…

    2026年5月10日
    000
  • 使用Flexbox和JavaScript实现动态布局切换与内部元素重排

    本教程详细阐述如何利用CSS Flexbox和JavaScript实现网页布局的动态切换,包括主容器的垂直/水平方向调整,以及内部文本输入框的同步重排。通过精心设计的HTML结构、CSS样式和JavaScript逻辑,我们能够创建一个响应式且用户友好的界面,允许用户根据需求灵活切换内容展示方式,确保…

    2026年5月10日
    100
  • Opencart 错误:尝试访问布尔类型值的数组偏移量

    本文旨在解决 Opencart 安装主题时出现的 “Notice: Trying to access array offset on value of type bool” 错误,该错误通常发生在模块试图访问布尔类型变量的数组偏移量时。我们将分析错误原因,并提供相应的解决方案…

    2026年5月10日
    000
  • React Router与Firebase认证:构建安全保护路由的实践指南

    本文深入探讨了在React应用中使用React Router和Firebase Authentication实现保护路由时常见的无限重定向问题。核心在于组件初次渲染时认证状态未就绪,导致误判。通过引入useEffect钩子监听Firebase认证状态变化,并结合加载状态管理,可以有效解决这一问题,确…

    2026年5月10日
    100
  • JavaScript 动态生成带 ID 的 Div 元素

    本文旨在解决在 JavaScript 中使用 forEach 循环动态创建 div 元素时,如何为每个 div 元素赋予唯一 ID 的问题。通过结合循环索引和字符串拼接,可以高效地为每个新创建的 div 元素设置不同的 ID,方便后续的 DOM 操作和样式控制。文章将提供清晰的代码示例和详细的解释,…

    2026年5月10日
    100
  • html5证书怎么查_html5用SSL证书工具查站点HTTPS证书有效性【查询】

    验证HTTPS证书有效性需三步:一、浏览器开发者工具查证书信息;二、在线SSL检测工具分析证书链与OCSP状态;三、OpenSSL命令行本地验证并提取证书详情。 如果您尝试验证某个网站是否正确部署了适用于HTML5环境的HTTPS证书,或需确认其SSL证书是否有效、未过期、匹配域名且由可信机构签发,…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信