• 技术文章 >php框架 >Laravel

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

    藏色散人藏色散人2020-10-13 10:23:01转载238

    下面由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\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!

    以上就是Sight!一个杀手级提升Laravel开发速度的组件现在开源了!的详细内容,更多请关注php中文网其它相关文章!

    本文转载于:learnku,如有侵犯,请联系a@php.cn删除
    专题推荐:laravel Sight
    上一篇:说说Laravel模型关联关系最单纯的“一对一”! 下一篇:Laravel如何使用laravel-snappy包实现HTML转PDF和PNG
    第13期线上培训班

    相关文章推荐

    • laravel new 命令为什么没有效果• 分享Laravel模型使用的2个小技巧• laravel系统自带的文件上传功能• 说说Laravel模型关联关系最单纯的“一对一”!

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网