成都网站建设设计

将想法与焦点和您一起共享

Sight组件的优点有哪些

本篇内容介绍了“Sight组件的优点有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

创新互联公司专注为客户提供全方位的互联网综合服务,包含不限于成都做网站、成都网站建设、成都外贸网站建设、张湾网络推广、微信小程序、张湾网络营销、张湾企业策划、张湾品牌公关、搜索引擎seo、人物专访、企业宣传片、企业代运营等,从售前售中售后,我们都将竭诚为您服务,您的肯定,是我们最大的嘉奖;创新互联公司为所有大学生创业者提供张湾建站搭建服务,24小时服务热线:18980820575,官方网址:www.cdcxhl.com

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组件的优点有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


新闻标题:Sight组件的优点有哪些
分享URL:http://chengdu.cdxwcx.cn/article/ijgsho.html