Primer React 37.18.0版本发布:增强分页与选择面板功能
项目简介
Primer React是GitHub设计系统Primer的React实现版本,提供了一套完整的UI组件库。作为GitHub官方维护的前端工具库,它帮助开发者快速构建符合GitHub设计规范的用户界面。最新发布的37.18.0版本带来了一系列功能增强和问题修复,特别在分页组件和选择面板方面有显著改进。
主要功能更新
分页组件增强
本次更新为Pagination组件新增了renderPage属性,这一改进让开发者能够更灵活地自定义分页按钮的渲染方式。通过这个属性,开发者可以完全控制每个页码按钮的呈现形式,无论是样式、内容还是交互行为,都能根据项目需求进行定制。
选择面板空状态支持
SelectPanel组件现在支持空状态显示,这一功能目前处于特性标志(Feature Flag)保护下。当选择面板没有可选项时,开发者可以配置特定的空状态UI,提升用户体验。这种设计模式在数据加载或过滤结果为空的场景下特别有用。
状态标签新增样式
StateLabel组件新增了open和closed两种状态的样式支持,特别针对不需要图标的场景。这一改进使得状态标签在纯文本展示时也能保持视觉一致性,丰富了组件的使用场景。
技术实现细节
组件元数据导出
本次更新新增了对@primer/react/generated/components.json的导入支持。这个JSON文件包含了组件的结构化元数据,为自动化工具和文档生成提供了便利。开发者可以利用这些元数据进行代码分析、文档生成或其他自动化处理。
对话框滚动优化
Dialog组件的页脚现在能够在非常短的视口中保持可滚动性。这一改进通过CSS调整实现,确保了在有限空间内对话框内容的可访问性。同时,对话框的压力测试故事(story)也进行了更新,使其在窄屏幕上能够全屏显示。
覆盖层定位修复
Overlay组件修复了在窄屏幕上全屏覆盖层定位的问题。这一修复确保了覆盖层在不同屏幕尺寸下都能正确定位,提升了响应式设计的可靠性。
问题修复与优化
键盘提示无障碍改进
KeybindingHint组件修复了与aria-labelledby属性结合使用时可能导致标签显示不正确的问题。这一修复针对Chrome浏览器的特定bug提供了解决方案,提升了无障碍访问体验。
页面标题字体修复
PageHeader组件现在使用font-weight: initial来匹配样式组件的样式定义,解决了字体粗细显示不一致的问题。
总结
Primer React 37.18.0版本通过新增功能和问题修复,进一步提升了组件的灵活性和稳定性。这些改进特别关注了开发者自定义需求和无障碍访问体验,体现了项目团队对细节的关注和对开发者体验的重视。对于正在使用或考虑使用Primer React的团队来说,这个版本值得关注和升级。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0191
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0117
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08