首页
/ BBC Psammead 项目代码规范与工作方式详解

BBC Psammead 项目代码规范与工作方式详解

2025-06-08 13:13:07作者:翟萌耘Ralph

前言

BBC Psammead 是一个用于构建 BBC 数字产品的组件库,它遵循严格的设计系统和开发规范。本文将深入解析该项目的代码标准和工作方式,帮助开发者更好地理解和使用这个组件库。

核心代码规范

REM 单位的使用规范

Psammead 项目中统一使用 REM (Root EM) 作为尺寸单位,这是项目中最具特色的规范之一。

REM 的优势:

  • 相对于根元素(html)的固定比例关系
  • 全局一致性,避免 EM 的级联问题
  • 简化响应式设计实现
  • 便于维护统一的视觉层次

实际应用示例:

export const GEL_SPACING = '0.5rem'; // BBC 标准间距单位

开发者须知:

  1. 所有间距、尺寸都应基于 REM 单位
  2. 避免混用 px、em 等其他单位
  3. 使用预定义的间距常量保持一致性

视觉回归测试

ChromaticQA 深度解析

Psammead 采用 ChromaticQA 作为视觉回归测试工具,这是保障组件库视觉一致性的关键环节。

工作流程:

  1. 首次运行建立基线截图
  2. 后续提交自动对比变更
  3. 开发者审查差异并确认/拒绝变更

技术特点:

  • 多浏览器支持(Chrome, IE, Firefox)
  • 独立跟踪每个故事的基线
  • 分支隔离的测试环境

本地测试方法:

export CHROMATIC_APP_CODE=<your-app-code>
npx chromatic test run --build-script-name build:storybook || true

最佳实践:

  • 定期审查视觉回归结果
  • 对预期变更明确标记
  • 保持测试环境一致性

无障碍性测试规范

无障碍性群体测试(Accessibility Swarm)

Psammead 对无障碍性有严格要求,采用群体测试方法确保组件可用性。

测试流程:

  1. 新组件:完整群体测试
  2. 现有组件变更:简化测试
  3. 使用支持的辅助技术验证

测试要点:

  • 屏幕阅读器兼容性
  • 键盘导航流畅性
  • 色彩对比度达标
  • ARIA 属性正确性

问题处理:

  • 详细记录发现的问题
  • 严重问题应创建专门工单
  • 修复后需重新验证

Storybook 使用指南

组件预览最佳实践

Storybook 是 Psammead 组件开发和展示的核心工具。

关键技巧:

  1. 独立标签查看:避免 iframe 对辅助技术的影响

    • 在组件菜单中选择"Open canvas in new tab"
  2. 本地隧道预览:未合并代码的跨设备测试

    yarn install:packages
    yarn storybook
    # 然后使用隧道工具暴露端口
    
  3. 生产环境更新:合并后自动发布到 Storybook 线上版本

调试建议:

  • 使用独立标签测试辅助技术
  • 验证各状态下的组件表现
  • 检查控制台警告/错误

版本管理与发布

Psammead 采用语义化版本控制,发布流程自动化程度高。

发布后验证:

  1. 确认 npm 包版本更新
    npm show {package-name} version
    
  2. 检查线上 Storybook 更新
  3. 验证依赖项目的构建情况

结语

BBC Psammead 的这套代码规范和工作流程体现了大型项目对质量控制的严格要求。通过 REM 单位的统一使用、严格的视觉回归测试、全面的无障碍性验证以及规范的 Storybook 工作流程,确保了组件库的高质量和一致性。开发者在使用或贡献代码时,应当充分理解并遵循这些规范,以维护项目的整体质量。

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

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
871
515
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
131
184
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
346
380
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
334
1.09 K
harmony-utilsharmony-utils
harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
ArkTS
31
0
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.08 K
0
kernelkernel
deepin linux kernel
C
22
5
WxJavaWxJava
微信开发 Java SDK,支持微信支付、开放平台、公众号、视频号、企业微信、小程序等的后端开发,记得关注公众号及时接受版本更新信息,以及加入微信群进行深入讨论
Java
829
22
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
603
58