乐趣区

关于php:Sight杀手级提升Laravel开发速度的组件现在开源了

Sight——杀手级晋升 Laravel 开发速度的组件当初开源了!
明天,给大家推存一个 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\Presenter

use 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!

退出移动版