高复用函数需控边界、明职责、留余地:参数支持数组/关联键/默认值三合一,返回统一结构+状态码+异常开关,逻辑通过回调插拔,命名规范且自动加载。

写好一个自定义函数不难,但让函数真正“高复用、易维护、可组合、少出错”,需要在设计思路上下功夫。核心不是堆功能,而是控边界、明职责、留余地。
参数灵活:支持数组 + 关联键 + 默认值三合一
别只用固定顺序的参数列表。用 func_get_args() 或更推荐的 ...$args(PHP 5.6+)接收动态参数,再用 array_merge() 合并默认配置与用户传入项。关键点是:把“必填逻辑”和“可选配置”分开处理。
- 用 is_array($args[0]) 判断是否传了配置数组,是则直接解析;否则按传统位置参数处理
- 默认配置用 const DEFAULT_OPTS = [...] 定义,避免硬编码散落
- 对关键参数做 isset() + !== null 双重校验,防止 false/0/'' 被误判为未传
返回健壮:统一结构 + 显式状态码 + 可选异常开关
别让调用方猜函数成功没。返回数组结构如 ['ok' => true, 'data' => ..., 'msg' => ''],比单纯 return $result 更可控。加一个 $throwOnError = false 参数,让使用者决定错误是抛异常还是静默返回失败结构。
- 内部用 try/catch 包裹可能出错逻辑,捕获后根据 $throwOnError 决策行为
- 状态码建议用整数(如 200 成功、400 参数错、500 系统错),比字符串更易判断和日志追踪
- 敏感数据(如密码、token)不在返回数组中透出,需额外字段控制是否包含
行为可插拔:用回调函数预留扩展点
函数内部别写死处理逻辑。比如格式化时间,不要直接写 date('Y-m-d', $ts),而是接受一个 $formatter = null 参数。若传了 callable,就交由它处理;没传则走默认。
立即学习“PHP免费学习笔记(深入)”;
- 用 is_callable($formatter) 校验,避免运行时报错
- 把常用 formatter 封装成静态方法(如 MyHelper::isoDate()),方便复用和测试
- 回调参数保持简洁,一般只传原始值和上下文数组,避免耦合过重
自动加载与命名规范:让函数模块真正“即装即用”
把一组相关函数放进独立文件(如 str_utils.php),文件名小写+下划线,函数名用 前缀_动词_名词(如 str_trim_whitespace())。配合 Composer 的 files 自动加载,或用 spl_autoload_register() 按需载入。
- 避免函数名冲突:项目级统一前缀(如 app_、blog_),不依赖 namespace(因函数非类)
- 每个文件顶部加简短注释说明用途、依赖、示例,不用 phpDoc 大段文档,但关键约束要写清(如“仅支持 UTF-8 字符串”)
- 函数文件不执行逻辑,只声明;初始化动作(如 setlocale)放在单独 init 函数里,由使用者显式调用
基本上就这些。高复用不是靠加功能堆出来的,是靠收接口、松耦合、留活口一点点磨出来的。











