当前位置: 首页 > news >正文

PHP全局函数与工具类设计

PHP全局函数与工具类设计

全局函数和工具类在项目中很常用。好的设计让工具代码更易用。今天说说PHP中全局函数和工具类的设计。

辅助函数文件。

```php
// helpers.php

function str_limit(string $value, int $limit = 100, string $end = '...'): string
{
if (mb_strlen($value) <= $limit) return $value;
return mb_substr($value, 0, $limit) . $end;
}

function str_random(int $length = 16): string
{
return bin2hex(random_bytes($length / 2));
}

function money_format(float $amount, string $symbol = '¥'): string
{
return $symbol . number_format($amount, 2);
}

function array_only(array $array, array $keys): array
{
return array_intersect_key($array, array_flip($keys));
}

function array_except(array $array, array $keys): array
{
return array_diff_key($array, array_flip($keys));
}

echo str_limit("这是一段很长的文本内容", 6) . "\n";
echo str_random(16) . "\n";
echo money_format(12345.67) . "\n";
?>

工具类的设计。

```php
class Str
{
public static function limit(string $value, int $limit = 100, string $end = '...'): string
{
if (mb_strlen($value) <= $limit) return $value;
return mb_substr($value, 0, $limit) . $end;
}

public static function random(int $length = 16): string
{
return bin2hex(random_bytes($length / 2));
}

public static function slug(string $title): string
{
$title = preg_replace('/[^\x{4e00}-\x{9fff}a-zA-Z0-9\s]/u', '', $title);
$title = preg_replace('/\s+/', '-', trim($title));
return strtolower($title);
}

public static function contains(string $haystack, string $needle): bool
{
return str_contains($haystack, $needle);
}

public static function studly(string $value): string
{
return str_replace(' ', '', ucwords(str_replace(['-', '_'], ' ', $value)));
}

public static function camel(string $value): string
{
return lcfirst(self::studly($value));
}
}

class Arr
{
public static function only(array $array, array $keys): array
{
return array_intersect_key($array, array_flip($keys));
}

public static function except(array $array, array $keys): array
{
return array_diff_key($array, array_flip($keys));
}

public static function flatten(array $array): array
{
$result = [];
array_walk_recursive($array, function ($value) use (&$result) {
$result[] = $value;
});
return $result;
}

public static function first(array $array, callable $callback = null, mixed $default = null): mixed
{
foreach ($array as $key => $value) {
if ($callback === null || $callback($value, $key)) {
return $value;
}
}
return $default;
}

public static function pluck(array $array, string $value, ?string $key = null): array
{
$results = [];
foreach ($array as $item) {
$itemValue = data_get($item, $value);
if ($key === null) {
$results[] = $itemValue;
} else {
$itemKey = data_get($item, $key);
$results[$itemKey] = $itemValue;
}
}
return $results;
}
}

echo Str::limit("这是一段很长的文本内容", 6) . "\n";
echo Str::random(16) . "\n";
echo Str::slug("Hello World PHP") . "\n";
print_r(Arr::only(['a' => 1, 'b' => 2, 'c' => 3], ['a', 'c']));
?>

使用trait组织工具方法。

```php
trait Macroable
{
protected static array $macros = [];

public static function macro(string $name, callable $macro): void
{
static::$macros[$name] = $macro;
}

public static function __callStatic(string $method, array $parameters): mixed
{
if (isset(static::$macros[$method])) {
return (static::$macros[$method])(...$parameters);
}
throw new BadMethodCallException("方法不存在: $method");
}
}

class StringHelper
{
use Macroable;
}

StringHelper::macro('greet', fn(string $name) => "Hello, $name!");
echo StringHelper::greet('张三') . "\n";
?>

全局函数和工具类的设计没有定论。使用全局函数或静态工具类都可以。关键是保持命名一致性和团队约定。Laravel的Str和Arr类提供了很好的参考。

http://www.gsyq.cn/news/1487912.html

相关文章:

  • 门店实力大比拼!2026 深圳香奈儿包包回收全维度测评,收的顶稳居第一 - 奢侈品回收测评
  • 2026一次性浴巾哪家品质最好?主流优质品牌综合测评推荐 - 品牌测评鉴赏家
  • SPT-AKI Profile Editor:重新定义《逃离塔科夫》离线游戏的存档编辑体验
  • 基于Processor Expert的BLDC电机闭环控制系统设计与实践
  • Kronos金融大模型:股票预测的革命性突破与完整实战指南
  • 如何用Responsive Boilerplate构建移动端友好的导航菜单与下拉组件
  • 智慧校园后台系统源码:SpringBoot后端+Vue前端+MySQL脚本+详细配置指南
  • OpenCore引导修补技术深度解析:让老旧Mac硬件突破苹果官方限制的终极方案
  • 如何实现iOS应用的实时样式重载:Motif Live Reload功能详解
  • LPC55S1x低功耗实战:从电源管理到唤醒优化的嵌入式设计
  • Gemini 3.5-flash 功能全景:用 AI 实现邮件自动分类与摘要生成
  • Keras对抗生成网络高级技巧:实现BiGAN和AAE(对抗自编码器)模型
  • AI优化、GEO服务商综合测评:从优化实力到行业口碑,哪家更靠谱? - 品牌推荐大师
  • 2026年化妆培训院校科普|美业新手择校干货分享 - 品牌测评鉴赏家
  • 眼周缺水起皮该买哪款眼油?无限空瓶!3款温和修护眼油 - 全网最美
  • 终极黑苹果配置指南:OpCore-Simplify自动化EFI生成工具深度解析
  • 短视频矩阵一站式后台:多平台账号统管、智能发布与评论线索自动抓取
  • 为什么选择sqlitebiter?10大特性让数据转换效率提升300%
  • 佛山奢侈品手表回收实测测评:本地高端腕表回收靠谱平台添价收手表回收深度测评 - 薛定谔的梨花猫
  • 终极iOS布局方案:RFQuiltLayout让你的应用界面瞬间提升档次
  • 从麻将对局新手到数据分析高手:Akagi麻将AI助手的5个技能解锁
  • 2026机器人微型执行器润滑选购指南:主流品牌对比与权威推荐 - 资讯速览
  • 2026 年北京工商注册代办 TOP5 权威推荐榜单 - 互联网科技品牌测评
  • 3分钟用AI制作专业短视频:Pixelle-Video全自动视频创作神器
  • DSP56300 ESSI接口编程实战:从轮询到DMA的嵌入式音频数据传输
  • 豆包关键词排名:2026年GEO优化服务商TOP3测评 - 资讯速览
  • WiVRn社区贡献者访谈:听听开发者怎么说
  • 如何快速解决Windows运行库问题:智能修复工具完整指南
  • 2026年台州婚纱照/婚纱摄影综合实力十强榜单出炉 - 生活测评君
  • Adafruit-Pi-Finder背后的技术:ARP扫描与网络检测实现原理