如何创建支持依赖项注入(DI)的 PHP 函数库:创建 Composer 包作为函数库。实现函数库功能,如在文件中实现一个问候函数。安装 PhpDI 容器并创建容器配置,将函数库类作为工厂定义添加到容器中。在代码中使用函数库并注入依赖项,如使用容器获取函数库类的实例。在实际应用中,例如将用户数据保存到数据库,注入数据库连接以提高灵活性。
如何创建 PHP 函数库并使其支持依赖项注入
介绍
函数库是 PHP 中代码复用的强大工具。通过使用依赖项注入(DI),您可以编写更灵活、可测试的函数库。本文将向您介绍如何创建和使用支持 DI 的 PHP 函数库。
创建函数库
首先,您需要创建一个 Composer 包作为您的函数库。使用 composer 包管理器,通过运行以下命令创建一个新包:
composer init
填写包信息,然后运行以下命令安装 Composer 自动加载器:
composer install
现在,在您的项目中创建一个新目录,用作函数库代码。例如:
php └── vendor └── my-library └── src └── FunctionLibrary.php
实现函数库
在 FunctionLibrary.php
中,实现函数库功能。例如:
namespace MyLibrary; class FunctionLibrary { public function greet(string $name): string { return "Hello, $name!"; } }
配置依赖项注入
为了支持 DI,您需要使用一个容器来解决依赖项。本文将使用 PhpDI 容器。
在您的函数库包中安装 PhpDI:
composer require php-di/phpdi
接下来,在 src/config.php
中创建一个容器配置:
$containerBuilder = new \DI\ContainerBuilder(); $containerBuilder->addDefinitions([ 'MyLibrary\FunctionLibrary' => \DI\factory(function () { return new FunctionLibrary(); }) ]); $container = $containerBuilder->build();
使用函数库
现在,您可以在代码中使用您的函数库并注入依赖项:
use MyLibrary\FunctionLibrary; use DI\Container; $container = new Container(); $functionLibrary = $container->get(FunctionLibrary::class); echo $functionLibrary->greet('John'); // 输出:Hello, John!
实战案例
假设您有一个将用户数据保存到数据库的函数库。您可以在依赖项注入中注入数据库连接,从而使您的函数库更加灵活和可测试:
namespace MyLibrary; class UserRepository { private $connection; public function __construct(\PDO $connection) { $this->connection = $connection; } public function persist(User $user): void { // 保存用户到数据库 } }
然后,在容器配置中添加以下定义:
$containerBuilder->addDefinitions([ \PDO::class => \DI\factory(function () { return new \PDO('mysql:host=localhost;dbname=my_database', 'username', 'password'); }), 'MyLibrary\UserRepository' => \DI\factory(function (Container $container) { return new UserRepository($container->get(\PDO::class)); }) ]);
以上是如何创建 PHP 函数库并使其支持依赖项注入?的详细内容。更多信息请关注PHP中文网其他相关文章!