第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定

Sight——殺手級(jí)提升Laravel開發(fā)速度的組件現(xiàn)在開源了!

標(biāo)簽:
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!

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

點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消