首页
/ USWDS 3.12.0版本发布:增强日期选择器与页面导航功能

USWDS 3.12.0版本发布:增强日期选择器与页面导航功能

2025-06-09 21:09:30作者:霍妲思

USWDS(U.S. Web Design System)是美国政府推出的前端设计系统,旨在为联邦政府网站提供一致、美观且符合可访问性标准的UI组件和设计模式。该系统基于现代Web技术构建,包含了丰富的Sass样式和JavaScript组件,帮助开发者快速构建符合政府标准的Web应用。

主要功能更新

日期选择器本地化支持

在3.12.0版本中,USWDS对日期选择器组件(usa-date-pickerusa-date-range-picker)进行了重要改进,引入了原生JavaScript的国际化支持。现在,日期选择器日历标签能够根据文档的lang属性自动生成翻译后的文本,这一功能通过Date.toLocaleStringAPI实现。

这一改进意味着开发者不再需要手动为不同语言环境配置日历标签,系统会根据用户浏览器的语言设置自动显示相应语言的月份、星期等标签,大大简化了多语言支持的实现过程。

页面内导航组件增强

页面内导航组件(usa-in-page-navigation)新增了data-minimum-heading-count属性,用于控制组件在内容区域中的显示条件。默认情况下,当内容区域中的标题数量少于2个时,该导航组件将自动隐藏。

这一改进解决了在小内容页面中不必要显示导航组件的问题,开发者可以根据实际内容结构调整这个阈值,使导航显示更加智能和符合上下文需求。

此外,该版本还修复了页面内导航无法滚动到嵌套标题(如卡片和摘要框中的标题)的问题,现在导航功能可以平滑滚动到页面中的任何层级标题。

工具提示功能扩展

工具提示组件(usa-tooltip)现在支持在非按钮元素上使用,扩展了组件的应用场景。开发者现在可以在更多类型的交互元素上添加工具提示,为用户提供更丰富的上下文帮助信息。

样式与交互改进

复选框与单选按钮优化

USWDS 3.12.0对复选框(usa-checkbox)和单选按钮(usa-radio)的样式进行了调整,使交互区域现在与内容宽度相匹配。在之前的版本中,这些元素的交互区域会扩展到容器的全宽,可能导致意外的点击区域过大问题。这一改进使表单控件的交互更加精确和符合用户预期。

Sass兼容性提升

为了确保与Dart Sass 2.0.0的兼容性,USWDS团队更新了颜色相关的Sass函数,消除了使用已弃用颜色函数的情况。这一改进使项目能够平滑过渡到最新的Sass版本,同时避免了相关的警告信息。

技术架构优化

在依赖管理方面,3.12.0版本移除了resolve-id-refs依赖项,改用自定义JavaScript实现相关功能,减少了外部依赖,提高了项目的可维护性。同时,开发依赖也进行了多项更新,包括Babel、PostCSS、Sass等工具的版本升级,确保开发工具链保持最新状态。

值得注意的是,USWDS项目现在要求所有提交都必须包含验证签名,这一安全措施提高了代码来源的可信度,有助于维护项目的完整性。

总结

USWDS 3.12.0版本在保持系统稳定性的同时,带来了多项实用改进,特别是在国际化支持和组件灵活性方面。日期选择器的自动翻译功能减轻了多语言支持的工作量,页面内导航的智能显示和滚动修复提升了用户体验,而工具提示的功能扩展则为开发者提供了更多设计可能性。这些更新共同使USWDS成为一个更加强大、灵活的前端设计系统,能够更好地服务于美国政府网站的建设需求。

登录后查看全文
热门项目推荐
相关项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
24
9
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
9
1
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
64
19
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
392
3.89 K
flutter_flutterflutter_flutter
暂无简介
Dart
671
156
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
23
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
JavaScript
261
322
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
661
311
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.2 K
654
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
15
1