這篇文章主要介紹Laravel中Sight組件有什么用,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

Laravel開(kāi)發(fā)速度可以算是最快的了。但是,現(xiàn)在如果加上Sight,那么,你的開(kāi)發(fā)速度會(huì)更加快。
Sight做了什么呢?
Sight是在Server Side實(shí)現(xiàn)了一個(gè)Presenter層。從而讓你把從服務(wù)器中查出的數(shù)據(jù)輕松轉(zhuǎn)換為可展示的數(shù)據(jù)。自從有了Sight,Laravel成了支持Server Side的MVP模式的框架。
為什么要用Sight呢?
一、是加快開(kāi)發(fā)速度。
二、國(guó)內(nèi)的Phper都了解,大廠是禁止SQL聯(lián)表三個(gè)表以上的。遇到初學(xué)者,會(huì)在FOR循環(huán)中查詢數(shù)據(jù)庫(kù)。如果你禁止了,則還有可能是,他們把相關(guān)ID PLUCK出來(lái)。查出結(jié)果,然后,再FOR循環(huán)中嵌套FOR循環(huán)去查相關(guān)的關(guān)聯(lián)數(shù)據(jù)。
Sight則是提供了很好的Pluck函數(shù),查出ID后,請(qǐng)求到相關(guān)數(shù)據(jù)交給Sight,Sight會(huì)為你拼接好數(shù)據(jù)。它的做法是通過(guò)關(guān)聯(lián)ID為KEY把數(shù)據(jù)整理好。從而大大提升了程序效率。
三、Sight的使用相當(dāng)簡(jiǎn)單。
比如以下示例,幾乎類似于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轉(zhuǎn)換成了時(shí)間,把created_by從user id轉(zhuǎn)換成了用戶名。
我們看出:created_at所用的是MappingTypeEnum::METHOD_NAME,這個(gè)方法在哪里呢,是在PresenterTrait中。所以,你也可以定義自己的Trait。
created_by則是直接讀取關(guān)聯(lián)數(shù)組中的user_name,因?yàn)橛玫氖荕appingTypeEnum::JOIN_FIELD。
上面代碼看起來(lái)有些長(zhǎng),但是,onRelationByObject()可以改用 onRelation()傳參方式,代碼就短了。
同樣addFieldMappingByObject(),改用addFieldMappingList()用數(shù)組傳入,代碼也短了。
Sight遠(yuǎn)遠(yuǎn)不只是這一點(diǎn)功能,它不僅支持MySQL查出的數(shù)據(jù),同時(shí)支持ElasticSearch查出的數(shù)據(jù)。
雖然是純數(shù)組操作,它一樣也有innerJoin和outerJoin,并且,有hasOne,hasMany ……
當(dāng)然,還有更多的功能,這個(gè)你就要仔細(xì)看文檔了。
Sight試圖解決你查出數(shù)據(jù)后,將其轉(zhuǎn)換成可展示數(shù)據(jù)中的不爽,它做得很好,真的能讓你 Coding More Happy; Coding More Quickly!
Github 地址: https://github.com/BardoQi/Sight
Sight——?dú)⑹旨?jí)提升Laravel開(kāi)發(fā)速度的組件現(xiàn)在開(kāi)源了!趕緊FORK,趕緊STAR!
以上是“Laravel中Sight組件有什么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站標(biāo)題:Laravel中Sight組件有什么用-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)路徑:http://chinadenli.net/article30/dpijpo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、網(wǎng)站收錄、云服務(wù)器、商城網(wǎng)站、外貿(mào)建站、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容