首页 >后端开发 >php教程 > 正文

PHP 扩展开发检测清单

原创2018-04-23 11:19:130449

这篇文章介绍的内容是关于PHP 扩展开发检测清单,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

这里写图片描述

想要做出一个成功的 PHP 扩展包,不仅仅是简单的将代码放进文件夹中就可以了,除此之外,还有非常多的因素来决定你的扩展是否优秀。以下清单的内容将有助于完善你的扩展,并且在 PHP 社区中得到更多的重视。

1. 为你的扩展选择一个正确合适的名字

  • 确保你的命名没有被其他项目使用。

  • 扩展的名字需要和你的 PHP 命名空间保持一致。

  • 不要在你的命名空间中使用自己的姓名或者其他带有个人色彩的东西。

2. 将你的扩展开源

  • GitHub 可以免费管理这一类公共的项目。

  • GitHub 非常有助于你来管理这个开源项目,并且方便他人获取你的扩展。

  • 如果你不想使用,可以尝试替代品: Bitbucket.

3. 对自动加载友好一些

  • 使用 PSR-4 兼容的自动加载器命名空间。

  • 请将代码放在 src 文件夹里。

4. 通过 Composer 发布

  • 确保可以通过 Composer 来找到你的类库, Composer 是PHP的一个依赖管理工具

  • 发布在 Packagist上,Packagist 是一个主要的 Composer 包仓库。

5. 不局限于框架

  • 不要局限于项目只能使用在一个框架上。

  • 通过服务提供器来给框架提供特殊支持。

6. 遵循一种编码风格

  • 强烈建议你坚持使用 PSR-2 编码风格。

  • 使用代码自动格式化工具,比如 PHP Coding Standards Fixer 。

  • 使用代码风格检测工具,比如 PHP Code Sniffer 。

7. 编写单元测试

  • 覆盖大部分的代码。

  • 使用 PHPUnit ,一个常用的 PHP 单元测试框架。

  • 其他可选: phpspec , Behat , atoum , Codeception。

8. 为代码写注释

  • 将注释当作内置文档来看待。

  • 代码注释也可以改善 IDE 的代码自动完成功能, 比如 PhpStorm 。

  • 可以自动转换成 API 文档, 查看 phpDocumentor 。

9. 使用语义化版本管理

  • 使用 语义化版本号 来管理版本号。

  • 遵循 主版本.次版本.补丁版本 规范。

  • 让开发人员安全的升级软件,而不用担心会产生破坏性的改动。

  • 请记得及时给发布版本打上标签!

10. 保持定期更新日志

  • 明确标记并展示出版本之间显著的变化。

  • 考虑遵循 Keep a CHANGELOG 的格式进行编写。

11. 使用持续集成

  • 使用服务来自动检查编码是否标准并且能否通过运行测试。

  • 在多个不同的 PHP 版本都进行运行测试会是个不错的办法。

  • 确保提交或者拉取的时候都可以自动运行。

  • 参考:Travis-CI,Scrutinizer, Circle-CI。

12. 编写大量的使用文档

  • 一份优秀的文档对于扩展包来说至关重要。

  • 至少要确保库中有详细的 README (自述) 文件。

  • 可以尝试在 GitHub Pages 中托管文档。

  • 可用参考: Read the Docs。

13. 包含一份授权(License)

  • 包含一份授权协议,能够很有效地保护你的工作成果,并且很容易做到。

  • 参考 choosealicense.com。 大部分PHP 开源项目使用 MIT 协议。

  • 至少要在代码库中包含 LICENSE 文件。

  • 还可以考虑在 Docblocks 中加入你的授权协议。

14. 欢迎大家的贡献

  • 想要大家辅助改进项目,那一定要多多请求大家的贡献!

  • 有一份 CONTRIBUTING 文件,列出贡献者的名单。

  • 利用这份文件解释项目环境要求,例如测试环境。

更多现代化 PHP 知识,请前往 Laravel / PHP 知识社区

相关推荐:

PHP扩展开发教程总结

php扩展开发

以上就是PHP 扩展开发检测清单的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码

声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理

  • 相关标签:php 清单 检测
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • 专题推荐

    作者信息
    推荐视频教程
  • javascript初级视频教程javascript初级视频教程
  • jquery 基础视频教程jquery 基础视频教程
  • 视频教程分类