使用本地 Composer 依赖项开发 Laravel 包

发布日期 作者

Developing Laravel Packages with Local Composer Dependencies image

通过本地文件符号链接在本地开发 Composer 包,当您要创建 Laravel 包并在真实应用程序中试用时,可以极大地提高开发速度。我正在阅读 Caleb Porzio 撰写的关于 花哨的 bash 别名 的文章,该别名灵感来自 npm link

我一直致力于改进我的本地工作流程,将 Laravel 包从开发阶段过渡到发布阶段,我经常发现自己通过 GitHub 仓库安装依赖项,然后一遍又一遍地运行 composer update,因为我比较懒惰。

我想记录一下我的工作流程,用于开发新的和现有的 Laravel 包并在真实的 Laravel 应用程序中运行它们,所有操作都在本地进行。

包设置

我将带您一步一步地创建一个从头开始的快速 Composer 包,并添加一个服务提供者。我知道一些包开发人员使用样板库作为 PHP 和 Laravel 包的起点(查看 Spatie 的 PHP 样板 以获得灵感)。

首先,让我们创建一个示例 composer 项目,并连接一个 Laravel 服务提供者。我喜欢从 ~/code 开始我的代码,因此请更新到您使用的任何位置

cd ~/code
mkdir example-pkg
cd example-pkg/
mkdir src/
composer init
# Walk through the prompts to init...

生成 composer.json 文件后,让我们添加一些内容,用于自动加载和自动服务提供者

{
"name": "paul/example-package",
"authors": [
{
"name": "Paul Redmond",
"email": "[email protected]"
}
],
"autoload": {
"psr-4": {
"ExamplePackage\\": "src/"
}
},
"require": {},
"extra": {
"laravel": {
"providers": [
"ExamplePackage\\ExamplePackageServiceProvider"
]
}
}
}

最后,让我们创建一个基本的服务提供者

<?php
 
namespace ExamplePackage;
 
use Illuminate\Support\ServiceProvider;
 
class ExamplePackageServiceProvider extends ServiceProvider
{
public function boot()
{
# code...
}
 
public function register()
{
# code...
}
}

将您的包链接到 Laravel 项目

现在我们已经拥有了一个可以用于开始开发新的 Laravel 包的本地 composer 项目,让我们创建一个演示 Laravel 应用程序,使用本地文件路径将我们的示例包链接起来

cd ~/code
laravel new laravel-demo
cd laravel-demo

我建议您查看 Caleb Portzio 的 bash 别名,但以下是要链接本地存储库所需的静态命令

composer config repositories.local '{"type": "path", "url": "../example-pkg"}' --file composer.json

接下来,我们需要运行 composer require,将本地存储库添加为依赖项。请记住使用您在 example-package composer 文件中定义的 "name"

composer require paul/example-package
 
Using version dev-master for paul/example-package
./composer.json has been updated
Loading composer repositories with package information
Updating dependencies (including require-dev)
Nothing to install or update
Generating optimized autoload files
> Illuminate\Foundation\ComposerScripts::postAutoloadDump
> @php artisan package:discover
Discovered Package: fideloper/proxy
Discovered Package: laravel/tinker
Discovered Package: nunomaduro/collision
Discovered Package: paul/example-package
Package manifest generated successfully.

您可以看到,我们的包是通过 composer.json 文件中的 "extra" 键发现的,太棒了!

如果您检查文件系统,您会注意到该包是符号链接的,这意味着您可以继续在本地开发该包,并立即在演示项目中试用它

cd ~/code/laravel-demo
ls -la vendor/paul
total 0
.
..
example-package -> ../../../example-pkg

现在,您拥有了一种极好的方法,可以在本地开发 Laravel 包,同时与 Laravel 应用程序并存!感谢 Caleb 提供了 很棒的别名

Paul Redmond photo

Laravel 新闻的编剧。全栈 Web 开发人员和作者。

Cube

Laravel 时事通讯

加入 40,000 多名其他开发者,绝不错过新的技巧、教程等等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

无妥协

来自 No Compromises 播客的两位经验丰富的开发人员 Joel 和 Aaron 现已开放,可以为您的 Laravel 项目提供服务。 ⬧ 固定价格为每月 7,500 美元。 ⬧ 无需漫长的销售流程。 ⬧ 无需签订合同。 ⬧ 100% 退款保证。

无妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

正在运行旧版本的 Laravel?即时、自动化的 Laravel 升级和代码现代化,让您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

每月仅需 2,500 美元,即可为您的项目配备一位经验丰富的 Laravel 开发人员,拥有 4-6 年的经验。获得 160 小时的专业知识和 15 天的无风险试用。立即安排通话!

Bacancy
Lucky Media logo

Lucky Media

立即获得幸运 - 拥有十多年经验的 Laravel 开发的理想选择!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar: Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的强大功能带到 Laravel。

Lunar: Laravel 电子商务
LaraJobs logo

LaraJobs

官方的 Laravel 工作板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS 启动工具包

SaaSykit 是一个 Laravel SaaS 启动工具包,包含运行现代 SaaS 所需的所有功能。支付、精美的结账流程、管理面板、用户仪表板、身份验证、现成的组件、统计信息、博客、文档等等。

SaaSykit: Laravel SaaS 启动工具包
Rector logo

Rector

您无缝升级 Laravel、降低成本和加速创新的合作伙伴,助力公司取得成功

Rector
MongoDB logo

MongoDB

通过强大的 MongoDB 和 Laravel 集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务性、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解 MongoDB 如何灵活、现代的数据库可以改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖项输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在您的 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel 提示构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包为您的 Laravel 应用程序添加评论

阅读文章