可通过封装公共逻辑为类方法或使用@脚本别名实现复用,优先推荐提取函数或类,在composer.json中用@引用其他脚本实现调用。

在一个 Composer 脚本中调用另一个已定义的脚本,不能直接通过名称“嵌套调用”,因为 Composer 不支持在脚本内部直接触发另一个命名脚本(如 post-install-cmd)的执行。但你可以通过以下几种方式实现类似效果。
1. 将逻辑提取为可复用的函数或类
最推荐的方式是把公共逻辑写成一个 PHP 函数或类方法,然后在多个脚本中调用它。例如,在你的项目中创建一个脚本处理类:
// scripts/ScriptHelper.php
class ScriptHelper
{
public static function runCommonTask($event)
{
echo "执行通用任务...\n";
// 你的逻辑
}
}
然后在 composer.json 中定义多个脚本,都调用这个方法:
"scripts": {
"post-install-cmd": ["ScriptHelper::runCommonTask"],
"post-update-cmd": ["ScriptHelper::runCommonTask"]
}
这样两个脚本共享同一段逻辑。
2. 在脚本中执行 shell 命令调用 composer run
如果你确实需要在一个脚本中触发另一个 Composer 脚本,可以通过 shell 执行composer run 命令。比如你有一个脚本叫 custom-script,想从 post-install-cmd 中调用它:
"scripts": {
"custom-script": "echo '这是被调用的脚本'",
"post-install-cmd": ["@call-custom-script"]
}
使用 @command 语法可以调用其他脚本:
"scripts": {
"custom-script": "echo '这是被调用的脚本'",
"call-custom-script": "@custom-script",
"post-install-cmd": ["@call-custom-script"]
}
触发式加载精美特效企业网站源码使用jquery实现了很多精美的触发式加载特效,网站首页在随着访客的滚动条滚动过程中会出现很多触发式加载的特殊效果,让这个网站的风格瞬间显得非常的高大上,让你的企业品牌在访客心中留下更深的影响。当然,我们在使用jquery特效的同时也要注意程序对搜索引擎的友好型,所以这一点儿作者也有考虑到,已经尽可能的对js和css脚本进行精简和优化,尽可能的加快网站加载速度,同时也
Composer 支持使用 @script-name 来间接调用另一个脚本。这属于 Composer 内部的别名机制。
注意:不能在 PHP 类方法中直接写 system('composer run custom-script'),除非你明确希望启动新的 Composer 进程,否则会导致递归或性能问题。
3. 使用脚本链式调用(通过 @ 符号)
Composer 允许你在脚本数组中使用@xxx 来引用其他脚本,实现组合调用。示例:
"scripts": {
"prepare-assets": "npm run build",
"optimize": "php artisan optimize",
"post-update-cmd": [
"@prepare-assets",
"@optimize"
]
}
这样 post-update-cmd 就会依次执行另外两个脚本。
总结:
- 优先把逻辑封装成类方法,在多个脚本中复用。
- 使用
@script-name可以在一个脚本序列中调用另一个脚本。
- 避免在 PHP 脚本中用系统命令调用
composer run,容易出问题。
- Composer 本身不支持在 PHP 回调函数中“编程式”触发另一个命名脚本的执行。
基本上就这些。









