在composer中,可通过环境变量或–分隔符向脚本传参,并使用&&、;等shell符号执行多个命令,复杂逻辑建议封装为独立脚本或类方法处理。

在 Composer 中,scripts 允许你定义在特定事件触发时运行的命令。你可能需要向脚本传递参数,或在一个 script 中执行多个命令。下面说明如何实现这两点。
传递参数给 scripts
Composer 自身不支持直接在 composer.json 的 scripts 中使用占位符来接收外部参数(如 shell 变量),但你可以通过以下方式间接实现:
- 使用环境变量:在运行 composer run 时设置环境变量,脚本中调用的命令读取这些变量。
- 示例:
COMPOSER_ENV=production composer run build
然后你的脚本可以调用一个 php 或 Shell 脚本,该脚本读取 COMPOSER_ENV 并做出相应处理。
也可以写一个封装脚本(如 build.php)来接收参数:
“scripts”: { “build”: “php build.php” }
运行时传参(注意:需用 — 分隔):
composer run build — –target=dist –minify
此时 –target=dist –minify 会作为参数传给 build.php,可在脚本中用 $argv 解析。
执行多个命令
一个 script 可以按顺序执行多个命令,使用 shell 的命令连接符即可:
- &&:前一个命令成功才执行下一个
- ;:无论成功与否都继续执行
- ||:前一个失败才执行下一个(用于 fallback)
示例:
“scripts”: { “deploy”: “php artisan clear-compiled && php artisan optimize && php artisan queue:restart” }
“scripts”: { “post-deploy”: “echo ‘Starting post-deploy…’ && php migrate.php && rm -rf cache/* && echo ‘Done'” }
更复杂的逻辑建议封装成独立脚本文件:
“scripts”: { “deploy”: “php deploy.php” }
使用闭包或类方法作为脚本处理器(高级)
Composer 支持使用 PHP 回调函数处理脚本,适合复杂逻辑和参数处理:
“scripts”: { “my-command”: “MyScriptHandler::myMethod” }
public static function myMethod(ComposerScriptEvent $event) { $args = $event->getArguments(); // 处理参数 }
运行时传参:
composer run my-command arg1 arg2 –option=value
基本上就这些。参数传递依赖外部机制(环境变量或 $argv),多个命令可用 shell 连接符或封装脚本处理。简单任务用 shell 命令链,复杂逻辑推荐独立脚本或类方法。