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

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

  • 确保你的命名没有被其他项目使用。
  • 扩展的名字需要和你的 PHP 命名空间保持一致。
  • 不要在你的命名空间中使用自己的姓名或者其他带有个人色彩的东西。

2. 将你的扩展开源

  • GitHub 可以免费管理这一类公共的项目。
  • GitHub 非常有助于你来管理这个开源项目,并且方便他人获取你的扩展。
  • 如果你不想使用,可以尝试替代品: Bitbucket.

3. 对自动加载友好一些

  • 使用 PSR-4 兼容的自动加载器命名空间。
  • 请将代码放在 src 文件夹里。

4. 通过 Composer 发布

  • 确保可以通过 Composer 来找到你的类库, Composer 是PHP的一个依赖管理工具
  • 发布在 Packagist上,Packagist 是一个主要的 Composer 包仓库。

5. 不局限于框架

  • 不要局限于项目只能使用在一个框架上。
  • 通过服务提供器来给框架提供特殊支持。

6. 遵循一种编码风格

7. 编写单元测试

8. 为代码写注释

  • 将注释当作内置文档来看待。
  • 代码注释也可以改善 IDE 的代码自动完成功能, 比如 PhpStorm
  • 可以自动转换成 API 文档, 查看 phpDocumentor

9. 使用语义化版本管理

  • 使用 语义化版本号 来管理版本号。
  • 遵循 主版本.次版本.补丁版本 规范。
  • 让开发人员安全的升级软件,而不用担心会产生破坏性的改动。
  • 请记得及时给发布版本打上标签!

10. 保持定期更新日志

  • 明确标记并展示出版本之间显著的变化。
  • 考虑遵循 Keep a CHANGELOG 的格式进行编写。

11. 使用持续集成

  • 使用服务来自动检查编码是否标准并且能否通过运行测试。
  • 在多个不同的 PHP 版本都进行运行测试会是个不错的办法。
  • 确保提交或者拉取的时候都可以自动运行。
  • 参考:Travis-CIScrutinizerCircle-CI

12. 编写大量的使用文档

  • 一份优秀的文档对于扩展包来说至关重要。
  • 至少要确保库中有详细的 README (自述) 文件。
  • 可以尝试在 GitHub Pages 中托管文档。
  • 可用参考: Read the Docs

13. 包含一份授权(License)

  • 包含一份授权协议,能够很有效地保护你的工作成果,并且很容易做到。
  • 参考 choosealicense.com。 大部分PHP 开源项目使用 MIT 协议
  • 至少要在代码库中包含 LICENSE 文件。
  • 还可以考虑在 Docblocks 中加入你的授权协议。

14. 欢迎大家的贡献

  • 想要大家辅助改进项目,那一定要多多请求大家的贡献!
  • 有一份 CONTRIBUTING 文件,列出贡献者的名单。
  • 利用这份文件解释项目环境要求,例如测试环境。

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

PHP 扩展开发检测清单(扩展开发必读)的更多相关文章

  1. PHP开发第一个扩展

    首先声明:我们要构建的是扩展或者模块名为hello_module.该模块提供一个方法:hello_word. 一.PHP环境的搭建 1)一般使用源码包编译安装,而不是binary包安装.因为使用PHP ...

  2. Chrome扩展开发之一——Chrome扩展的文件结构

    目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...

  3. iOS开发系列--App扩展开发

    概述 从iOS 8 开始Apple引入了扩展(Extension)用于增强系统应用服务和应用之间的交互.它的出现让自定义键盘.系统分享集成等这些依靠系统服务的开发变成了可能.WWDC 2016上众多更 ...

  4. Asp.net Mvc模块化开发之分区扩展框架

    对于一个企业级项目开发,模块化是非常重要的. 默认Mvc框架的AreaRegistration对模块化开发真的支持很好吗?真的有很多复杂系统在使用默认的分区开发的吗?我相信大部分asp.net的技术团 ...

  5. iOS开发---分类和扩展(Categories和Extensions)

      1.分类能够做到的事情主要是:即使在你不知道一个类的源码情况下,向这个类添加扩展的方法.   此外,分类能够保证你的实现类和其他的文件区分开.   1 #import “UIViewControl ...

  6. Chrome扩展开发之三——Chrome扩展中的数据本地存储和下载

    目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...

  7. web开发性能优化---扩展性能篇

    1.实现代码分离 一个成熟的软件开发团队一般都不会全然手写代码.这里讲的代码分离仅仅要是开发中用到的小技巧,通过底层框架+手工代码方式结合实现高速开发和高速扩展. Code目录内文件不同意改动,目录主 ...

  8. 我的VSTO之路(五):Outlook初步开发之联系人扩展

    原文:我的VSTO之路(五):Outlook初步开发之联系人扩展 上一讲我们完成对Word的介绍,文本开始,我将着重介绍Outlook.Outlook是微软Office中一个非常实用的工具,尤其在一个 ...

  9. 常用网站开发类Firefox扩展插件 (转)

    作为一个 Web 开发人员,你几乎没有理由不喜欢Firefox,因为在Firefox下有很多专门针对开发的扩展插件,非常好用,这里就介绍一些常用的针对网站开发的FireFox扩展,供Web开发人员参考 ...

随机推荐

  1. bzoj千题计划251:bzoj3672: [Noi2014]购票

    http://www.lydsy.com/JudgeOnline/problem.php?id=3672 法一:线段树维护可持久化单调队列维护凸包 斜率优化DP 设dp[i] 表示i号点到根节点的最少 ...

  2. nodeJs多进程Cluster

    在前端页面中,如果我们想进行多进程,我们会用到WebWorker,而在NodeJs中,我们如果想充分利用服务器核心资源,我们会用到Node中Cluster模块 直接上代码吧: const cluste ...

  3. node框架express

    见识到原生nodeJs服务器的恶心后,我们来用下简单好用的框架吧~ 服务器无非主要提供接口和静态文件读取,直接上代码: const express = require('express'); cons ...

  4. python全栈开发-json和pickle模块(数据的序列化)

    一.什么是序列化? 我们把对象(变量)从内存中变成可存储或传输的过程称之为序列化,在Python中叫pickling,在其他语言中也被称之为serialization,marshalling,flat ...

  5. OpenShift实战(三):OpenShift持久化存储Registry

    1.查看Registry组件的DC关于volume的定义 可以看到registry-storage这个挂载点被指向了一个/registry目录,使用的是empty directory,即数据保存在计算 ...

  6. PHP模式设计之单例模式、工厂模式、注册树模式、适配器模式、观察者模式

    php模式设计之单例模式 什么是单例模式? 单例模式是指在整个应用中只有一个实例对象的设计模式 为什么要用单例模式? php经常要链接数据库,如果在一个项目中频繁建立连接数据库,会造成服务器资源的很大 ...

  7. docker实践4

    我的docker学习笔记4-守护式容器   $docker run -i -t ubuntu /bin/bash $ctrl-p 或 ctrl-q # 转到后台   $docker ps $docke ...

  8. 移动端登录页面input获取焦点后页面布局及输入框上移的问题

    最近切微信页面的时候,发现移动端的登录页面,带输入框的那种,如图: 从页面本身来看没有什么问题,上传至测试服务器,用iphone访问也没有什么问题,但是当同事用Android手机获取焦点后,问题来了, ...

  9. [SHOI2009] 会场预约 - Treap

    Description PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也 ...

  10. 深入浅出Lua虚拟机

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 作者:郑小辉 | 腾讯 游戏客户端开发高级工程师 写在前面:本文所有的文字都是我手工一个一个敲的,以及本文后面分享的Demo代码都是我一行一 ...