Files
everything-claude-code/docs/zh-CN/rules/php/coding-style.md
2026-03-13 17:45:44 +08:00

37 lines
1.2 KiB
Markdown

---
paths:
- "**/*.php"
- "**/composer.json"
---
# PHP 编码风格
> 此文件在 [common/coding-style.md](../common/coding-style.md) 的基础上扩展了 PHP 相关内容。
## 标准
* 遵循 **PSR-12** 的格式化和命名约定。
* 在应用程序代码中优先使用 `declare(strict_types=1);`
* 在所有新代码允许的地方使用标量类型提示、返回类型和类型化属性。
## 不可变性
* 对于跨越服务边界的数据,优先使用不可变的 DTO 和值对象。
* 在可能的情况下,对请求/响应负载使用 `readonly` 属性或不可变构造函数。
* 对于简单的映射使用数组;将业务关键的结构提升为显式类。
## 格式化
* 使用 **PHP-CS-Fixer****Laravel Pint** 进行格式化。
* 使用 **PHPStan****Psalm** 进行静态分析。
* 将 Composer 脚本纳入版本控制,以便在本地和 CI 中运行相同的命令。
## 错误处理
* 对于异常状态抛出异常;避免在新代码中返回 `false`/`null` 作为隐藏的错误通道。
* 在框架/请求输入到达领域逻辑之前,将其转换为经过验证的 DTO。
## 参考
有关更广泛的服务/仓库分层指导,请参阅技能:`backend-patterns`