Sight!一个杀手级提升Laravel开发速度的组件现在开源了!

Sight!一个杀手级提升Laravel开发速度的组件现在开源了!,第1张

概述Sight!一个杀手提升Laravel开发速度的组件现在开源了!

下面由Laravel教程栏目给大家介绍Sight! ,希望对需要的朋友有所帮助!

今天,给大家推存一个Laravel的专用组件:Sight
Laravel开发速度可以算是最快的了。但是,现在如果加上Sight,那么,你的开发速度会更加快。
Sight做了什么呢?
Sight是在Server SIDe实现了一个Presenter层。从而让你把从服务器中查出的数据轻松转换为可展示的数据。自从有了Sight,Laravel成了唯一支持Server SIDe的MVP模式的框架。
为什么要用Sight呢?
一、是加快开发速度。
二、国内的PHPer都了解,大厂是禁止sql联表三个表以上的。遇到初学者,会在FOR循环中查询数据库。如果你禁止了,则还有可能是,他们把相关ID PLUCK出来。查出结果,然后,再FOR循环中嵌套FOR循环去查相关的关联数据。
Sight则是提供了很好的Pluck函数,查出ID后,请求到相关数据交给Sight,Sight会为你拼接好数据。它的做法是通过关联ID为KEY把数据整理好。从而大大提升了程序效率。
三、Sight的使用相当简单。
比如以下示例,几乎类似于Model的使用。

namespace App\Presenteruse bardoqi\Sight\Presenter;use bardoqi\Sight\Traits\PresenterTrait;use bardoqi\Sight\Enums\MapPingTypeEnum use bardoqi\Sight\Enums\PaginateTypeEnum use App\RepositorIEs\ArticleRepository;use App\RepositorIEs\UserRepository; class ArticlePresenter extents Presenter{   use PresenterTrait;   public function getArticleList($where)   {       $articleArray = ArticleRepository::getList($where);       $user_IDs = $this->selectFIElds('ID','Title','created_at','created_by')            ->fromLocal($articleArray,'articles')            ->pluck('created_by');       $users = UserRepository::getUsersWithIDs($user_IDs);       $this->innerJoinForeign($users,'useRSS')            ->onRelationByObject(Relation::of()                ->localAlias('articles')                ->localFIEld('created_by')                ->foreignAlias('users')                ->foreighFIEld('ID'))             ->addFIEldMapPingByObject(FIEldMapPing::of()                ->key('created_at')                ->src('created_at')                ->type(MapPingTypeEnum::METHOD_name))            ->addFIEldMapPingByObject(FIEldMapPing::of()                ->key('created_by')                ->src('user_name')                ->type(MapPingTypeEnum::JOIN_FIELD));                return $this->topaginateArray(PaginateTypeEnum::PAGINATE_API);   }}

上例中,代码则是把created_at从int转换成了时间,把created_by从user ID转换成了用户名。
我们看出:created_at所用的是MapPingTypeEnum::METHOD_name,这个方法在哪里呢,是在PresenterTrait中。所以,你也可以定义自己的Trait。
created_by则是直接读取关联数组中的user_name,因为用的是MapPingTypeEnum::JOIN_FIELD。
上面代码看起来有些长,但是,onRelationByObject()可以改用 onRelation()传参方式,代码就短了。
同样addFIEldMapPingByObject(),改用addFIEldMapPingList()用数组传入,代码也短了。

Sight远远不只是这一点功能,它不仅支持MysqL查出的数据,同时支持ElasticSearch查出的数据。
虽然是纯数组 *** 作,它一样也有innerJoin和outerJoin,并且,有hasOne,hasMany ……
当然,还有更多的功能,这个你就要仔细看文档了。

Sight试图解决你查出数据后,将其转换成可展示数据中的不爽,它做得很好,真的能让你 Coding More Happy; Coding More Quickly!

Github 地址: https://github.com/bardoQi/Sight

Sight——杀手级提升Laravel开发速度的组件现在开源了!赶紧FORK,赶紧STAR! 总结

以上是内存溢出为你收集整理的Sight!一个杀手级提升Laravel开发速度的组件现在开源了!全部内容,希望文章能够帮你解决Sight!一个杀手级提升Laravel开发速度的组件现在开源了!所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1227786.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-05
下一篇 2022-06-05

发表评论

登录后才能评论

评论列表(0条)

保存