Laraval IDE 自动补全助手:Laravel IDE Helper Generator

1、简介

该扩展包可以生成一个IDE可以理解的文件,以便提供精准的自动补全功能。这个生成的文件基于项目中存在的文件,所以永远是实时的。当然如果你不想手动生成这个文件,也可以使用预生成的文件并把它们放到项目根目录下(这些文件就没有那么实时了):

Larval 5:https://gist.github.com/barryvdh/5227822

Lumen:https://gist.github.com/barryvdh/be17164b0ad51f832f20

PHPStorm Meta 文件:https://gist.github.com/barryvdh/bb6ffc5d11e0a75dba67

注:Laravel 4.x请参考这里

2、安装

我们使用如下Composer命令安装扩展包相关依赖:

composerrequirebarryvdh/laravel-ide-helper

安装完成后我们需要到app/config.php的providers选项中注册服务提供者:

Barryvdh\LaravelIdeHelper\IdeHelperServiceProvider::class,

3、自动生成Laravel门面对应的phpDoc

在使用这个扩展包之前,或许不少人已经碰到了使用PHPStorm不能自动补全门面(Facade)的问题,现在Laravel IDE Helper Generator 为我们带来了福音。我们使用如下命令生成包含门面补全信息的文件:

php artisan ide-helper:generate

注意:在此之前需要清除bootstrap/compiled.php,所以生成之前需要先运行php artisan clear-compiled然后运行php artisan optimize。

为了后续方便,你也可以在composer.json文件中作如下配置:

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

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

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

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

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

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

4、自动生成模型对应的phpDoc

在使用本特性之前,需要先安装doctrine/dbal: ~2.3:

composerrequiredoctrine/dbal

如果你不想自己编写模型属性,可以使用php artisan ide-helper:models命令来基于数据表字段、关联关系以及getters/setters生成对应的phpDoc。你可以通过—write(-W)选项来编写模型文件的注释,默认情况下,你需要覆盖或新建一个单独的文件_ide_helper_models.php,你也可以通过—nowrite(-N)不做更改。需要注意的是在进行操作之前需要备份模型文件,因为我们要保留之前已存在的,只是追加新属性和方法,而不是覆盖和重写。phpdoc已存在会被替换,否则新增,通过—reset(-R)选项,已存在的phpdoc会被忽略,新增的字段/关系才会被保存。

phpartisan ide-helper:models Post

该命令会根目录下生成文件_ide_helper_models.php。

/** * An Eloquent Model:'Post'* * @property integer $id * @property integer $author_id * @property string $title * @property string $text * @property \Carbon\Carbon $created_at * @property \Carbon\Carbon $updated_at * @property-read\User $author * @property-read\Illuminate\Database\Eloquent\Collection|\Comment[] $comments */

默认情况下,app/models中的模型会被遍历,可以使用如下方式告诉哪些模型被使用:

phpartisan ide-helper:models Post User

还可以通过--dir选项浏览一个其他目录(基于根路径):

phpartisan ide-helper:models --dir="path/to/models"--dir="app/src/Model"

也可以发布配置文件(php artisan vendor:publish)并设置默认目录。

可以使用—ignore(-I)选项来忽略模型:

phpartisan ide-helper:models --ignore="Post,User"

可以通过命名空间包裹模型名称:php artisan ide-helper:models "API\User"

5、PHPStorm中容器实例对应的Meta

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

phpartisan ide-helper:meta

会在根目录下生成.phpstorm.meta.php文件。

app('events')->fire();\App::make('events')->fire();/**@var\Illuminate\Foundation\Application $app */$app->make('events')->fire();// When the key is not found, it uses the argument as class nameapp('App\SomeClass');

预生成示例:https://gist.github.com/barryvdh/bb6ffc5d11e0a75dba67

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


时间 : 2016-05-10 01:15:13 Laravel学院

原文 : http://laravelacademy.org/post/4202.html

主题: Laravel开发工具

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容