Laraval IDE 自动补全插件 laravel-ide-helper

一、背景

我们在实际的开发场景中,不少人或许已经碰到了使用PHPStorm不能自动补全门面(Facade)的问题,或者其他类通过容器调用时无法补全或者跳转。而插件 laravel-ide-helper就是用来解决这个问题的。

二、laravel-ide-helper介绍

Laravel IDE Helper 是一个比较好用的代码提示及补全工具,可以给编写代码带来极大的便利。该扩展包可以生成一个IDE可以理解的文件,以便提供精准的自动补全功能。这个生成的文件基于项目中存在的文件,所以永远是实时的。当然如果你不想手动生成这个文件,也可以使用预生成的文件并把它们放到项目根目录下(这些文件就没有那么实时了),但是不推荐这种方式,因为我们的目的就是为了好用!!!

Larval 5:https://gist.github.com/barryvdh/5227822
Lumen:https://gist.github.com/barryvdh/be17164b0ad51f832f20
PHPStorm Meta 文件:https://gist.github.com/barryvdh/bb6ffc5d11e0a75dba67

二、安装

2.1 方式一:通过composer require

进入到laravel项目,在项目目录下执行下面命令即可

composer require barryvdh/laravel-ide-helper  
# 仅在开发系统中安装提示包 加上 --dev
composer require barryvdh/laravel-ide-helper --dev

2.2 方式二:通过修改composer.json

版本根据实际情况进行调整

 "barryvdh/laravel-ide-helper": "^2.7",

 

 

 

注意1:如果你需要为模型注释字段,请安装 doctrine/dbal

composer require doctrine/dbal

注意2:Laravel版本小于5.5, 需要注册提供者:在 config/app.php 中的 providers 数组中加入

Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider::class,

 

 

 

或在 app/Providers/AppServiceProvider.php 文件中根据环境进行注册

public function register()
{
    if ($this->app->environment() !== 'production') {
        $this->app->register(\Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider::class);
    }
    // ...
}
PowerShell

 

 

 

文件信息:vendor/barryvdh/laravel-ide-helper/src/IdeHelperServiceProvider.php

 

 

 

三、用法

php artisan ide-helper:generate - 为 Facades 生成注释
php artisan ide-helper:models - 为数据模型生成注释
php artisan ide-helper:meta - 生成 PhpStorm Meta file

3.1 自动为 Laravel 的 Facades 生成注释

php artisan ide-helper:generate

注意:如果存在文件 「bootstrap/compiled.php」文件,则需要先删除, 可以在生成文当前运行

php artisan clear-compiled

当然你也可以在composer.json文件中作如下配置,这样可以自动运行 generate

scripts":{
    "post-update-cmd": [
        "php artisan clear-compiled",
        "php artisan ide-helper:generate",
        "php artisan optimize"
    ]
},

还可以发布配置文件以修改默认实现

php artisan vendor:publish --provider="Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider" --tag=config

生成器会尝试定位真正的类,如果找不到,可以在配置文件中定义。

有些类需要数据库连接,如果没有相应的数据库连接,某些门面可能无法包含进来。

你可以选择要包含的辅助函数文件,默认该选项并未开启,但是你可以通过--helpers选项覆盖默认配置。默认会引入Illuminate/Support/helpers.php,当然你还可以在配置文件中添加自定义的辅助函数文件。

3.2 自动为模型生成注释

php artisan ide-helper:models

//指定文件
php artisan ide-helper:models "App\Models\Admin"

为所有模型生成注释会出现询问,输入yes:

Do you want to overwrite the existing model files? Choose no to write to _ide_helper_models.php instead? (Yes/No):
PowerShell

输入 yes 则会直接在模型文件中写入注释,否则会生成「ide_helper_models.php」文件。强烈推荐选择 yes,这样在跟踪文件的时候不会跳转到「ide_helper_models.php」文件,不过这么做最好对模型文件做个备份,至少在生成注释之前用 git 控制一下版本,以防万一。

注意:为模型生成字段信息必须在数据库中存在相应的数据表,不要生成 migration 还没运行 migrate 的时候就生成注释,这样是得不到字段信息的。

3.3 自动为链式操作注释

这是什么意思呢?举个例子,在 migration 文件中经常可以看见这样的代码:

$table->string('email')->unique();
PowerShell

这时候就算调用过了 php artisan ide-helper:generate,在调用像 ->unique() 这样的链式操作的时候也无法实现代码提示,这时候需要将配置文件「如果导出的话」'include_fluent' => false 修改为 'include_fluent'=> true,重新运行 php artisan ide-helper:generate即可。

3.4 生成PHPStorm中容器实例对应的Meta

php artisan ide-helper:meta

可以生成一个PHPStorm meta文件来添加工厂设计模式支持,对Laravel而言,这意味着我们可以让PHPStorm理解从IoC容器中取出的对象类型。例如,events会返回Illuminate\Events\Dispatcher对象,因此通过meta文件你可以调用app('events')然后它会自动补全对应的调度方法。

执行php artisan ide-helper:meta命令后会在根目录下生成 .phpstorm.meta.php文件。

注意:你可能需要重启PHPStorm以确保.phpstorm.meta.php被索引。

四、知识拓展

知识扩展:Composer 在运行过程中将会触发以下事件:

事件名称详细说明
pre-install-cmd 在 install 命令执行前触发。
post-install-cmd 在 install 命令执行后触发。
pre-update-cmd 在 update 命令执行前触发。
post-update-cmd 在 update 命令执行后触发。
pre-status-cmd 在 status 命令执行前触发。
post-status-cmd 在 status 命令执行后触发。
pre-package-install 在资源包安装前触发。
post-package-install 在资源包安装后触发。
pre-package-update 在资源包更新前触发。
post-package-update 在资源包更新后触发。
pre-package-uninstall 在资源包被卸载前触发。
post-package-uninstall 在资源包被卸载后触发。
pre-autoload-dump 在自动加载器被转储前触发,无论是 install/update 还是 dump-autoload 命令都会触发。
post-autoload-dump 在自动加载器被转储后触发,无论是 install/update 还是 dump-autoload 命令都会触发。
post-root-package-install 在 create-project 命令期间,根包安装完成后触发。
post-create-project-cmd 在 create-project 命令执行后触发。

**注意:**Composer 不会去执行任何依赖包中定义的 install 或 update 相关脚本。因此你不应该在依赖包中申明 pre-update-cmd 或 pre-install-cmd。如果你需要在执行 install 或 update 命令前使用脚本,请确保它们已被定义在根包中。

 

 
posted @ 2022-01-15 17:46  joshua317  阅读(393)  评论(0编辑  收藏  举报