参加 Spartacus 开源项目开发时需要注意的一些编程规范

简介: 参加 Spartacus 开源项目开发时需要注意的一些编程规范

我们使用 NgRx 存储来管理 Spartacus 功能中的全局应用程序状态。 使用 NgRx 在性能、更好的可测试性和易于故障排除、方面具有明显的优势。


除非有令人信服的理由不这样做,否则在某项 feature 的开发里,请总是使用 Rgrx 来管理状态。


使用 Store 并不意味着我们需要缓存所有内容。 缓存应该有目的的使用,并在有意义的地方使用。 通常,CMS 数据是缓存的良好候选者,而应用程序数据则不是。


如果要从 UI 组件调用使用 NgRx 逻辑的功能,则应实现外观服务功能以公开功能并将 NgRx 代码封装在核心库中。


NgRx 的复杂性被封装在核心库中。 门面服务可从核心库中获得。 外观服务公开了核心库功能,但它们在其实现中隐藏了 NgRx 逻辑。


内置 Spartacus UI 组件不应包含 NgRx 逻辑。 相反,UI 组件应该调用外观服务函数。


下面是 unit Component 里使用 service 类的一个例子:


image.png


可以为每个页面更改站点上下文。 对于不同的站点上下文,响应数据可能不同。


此外,登录用户和匿名用户可能会看到不同的响应数据。 在页面上工作时,请考虑到用户可以通过登录或注销更改其登录状态。


尽量保持模块尽可能小。在大多数情况下,一个模块只有一个组件。此外,我们应该始终尝试减少模块依赖性。


单元测试必须覆盖所有代码。


关于端到端测试,基本的 UI 端到端测试以及可访问性端到端测试必须始终涵盖面向 UI 的新功能。 测试的文件名应以 e2e-spec.ts 结尾。 可以重复使用的公共函数应该被提取到不同的文件中,并且应该位于名为 helpers 的子目录中。 这些文件应以文件扩展名 .ts 结尾。


如果开发人员有多个用户流测试,请将它们分成单独的文件,以便它们可以并行运行。 我们还建议将测试分组到具有相关名称的子目录中。



相关文章
|
5月前
|
设计模式 存储 算法
C++从入门到精通:3.7阅读和理解开源项目——在实际项目中应用C++编程技巧和规范
C++从入门到精通:3.7阅读和理解开源项目——在实际项目中应用C++编程技巧和规范
114 0
|
5月前
|
数据采集 机器学习/深度学习 开发者
如何在实际项目中应用这些开源项目?
【2月更文挑战第14天】【2月更文挑战第41篇】如何在实际项目中应用这些开源项目?
41 4
|
5月前
|
机器学习/深度学习 分布式计算 JavaScript
有哪些常用的开源项目可以在实际项目中应用?
【2月更文挑战第14天】【2月更文挑战第42篇】有哪些常用的开源项目可以在实际项目中应用?
39 3
|
12月前
|
Cloud Native Go 开发者
如何通过开源项目学习编程?
如何通过开源项目学习编程?
135 0
|
存储 缓存 测试技术
参加 Spartacus 开源项目开发时需要注意的一些编程规范
参加 Spartacus 开源项目开发时需要注意的一些编程规范
|
前端开发 JavaScript IDE
推荐10个有趣的前端开源项目
开源的世界每天都丰富多彩,2022年前端领域会有什么新的挑战?下面是我们整理的10个有趣的开源项目,希望当中有您想要收藏的那一个。
1555 21
推荐10个有趣的前端开源项目
|
供应链 安全 IDE
墨菲安全正式发布 murphysec 开源项目!让开发者更安全的使用开源代码
墨菲安全正式发布 murphysec 开源项目!让开发者更安全的使用开源代码
499 0
墨菲安全正式发布 murphysec 开源项目!让开发者更安全的使用开源代码
|
Web App开发 JavaScript 测试技术
技术分享 | 学做测试平台开发-Vuetify 框架
技术分享 | 学做测试平台开发-Vuetify 框架
|
开发工具 git 开发者
向开源项目贡献代码那点事
向开源项目贡献代码那点事
146 0
|
测试技术 开发工具 git
【手把手指导】给开源项目贡献代码
很多新人学习了技术,但是没有地方施展。
364 0
【手把手指导】给开源项目贡献代码
下一篇
无影云桌面