承接 caffeinated/presenter 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

caffeinated/presenter

最新稳定版本:v2.1

Composer 安装命令:

composer require caffeinated/presenter

包简介

Laravel 5 View Presenters

README 文档

README

Caffeinated Presenter

Laravel 5.1 Laravel 5.2 Source License

Laravel 5 view presenters, originally developed after the Laracasts video tutorial on the same topic: View Presenters From Scratch.

Presenters allow you to manipulate any form of data for display within a view file. A simple example would be if you have a user entity with fields for the first and last names, how would you simply display the full name of the user within your view file? The most common solution would be something like the following:

<h1>Hello, {{ $user->first_name }} {{ $user->last_name }}!</h1>

Which works, but every time you need to display a user's full name, you'd have to type this out. What if instead it was something like this:

<h1>Hello, {{ $user->present()->fullName }}!</h1>

Isn't that much more readable than the previous example? Now you may argue that you could add this type of logic directly to your model class, which you could, but then you'll find that your model classes are riddled with methods that are manipulating view logic. I don't believe model entities should be responsible for this. Their only job is to pull the requested data from the database and hand it over. That's it.

Quick Installation

Begin by installing the package through Composer.

composer require caffeinated/presenter=~2.0

And that's it! With your coffee in reach, start building out some awesome presenters!

Usage

1. Pull in trait

Within your model, simply pull in the Caffeinated\Presenter\Traits\PresentableTrait trait, which will automatically instantiate the Caffeinated Presenter class.

...

use Caffeinated\Presenter\Traits\PresentableTrait;

class Example extends Eloquent
{
	use PresentableTrait;

	...
}

2. Define your presenter class

Define a protected $presenter variable pointing to the namespace of your presenter class.

...

use Caffeinated\Presenter\Traits\PresentableTrait;

class Example extends Eloquent
{
	use PresentableTrait;

	protected $presenter = 'App\Presenters\Page';

	...
}

3. Create your presenter class

Create a new class as defined within your model earlier - in our case we'll create a new directory within the app directory called Presenters, and create a Page file. Presenters should extend the abstract Caffeinated\Presenter\Presenter class.

<?php
namespace App\Presenters;

use Caffeinated\Presenter\Presenter;

class Page extends Presenter
{
	...
}

4. Define your presenter methods

Your model instance is passed through to your presenter class automatically, and is accessible via $this->entity. With that, you may now define any number of presenter methods here as you wish.

<?php
namespace App\Presenters;

use Caffeinated\Presenter\Presenter;

class Page extends Presenter
{
	public function title()
	{
		return ucwords($this->entity->title);
	}
}

The usage for the above would then be {{ $page->present()->title }}.

统计信息

  • 总下载量: 17.76k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 21
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 20
  • Watchers: 3
  • Forks: 6
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-02-09