# laravel5.4 | 视图
## 创建视图
视图文件存放在resources/views
Route::get('/', function () {
return view('greeting', ['name' => 'James']);
});
判断视图是否存在
if (view()->exists('emails.customer')) {
//
}
调用不带参数的 view 时,将会返回一个 Illuminate\Contracts\View\Factory 实例
## 传递数据到视图
return view('greetings', ['name' => 'Victoria']);
$view = view('greeting')->with('name', 'Victoria');
#### 在视图间共享数据
使用视图工厂的 share 方法
需要在服务提供者的 boot 方法中调用 share 方法,你可以将其添加到 AppServiceProvider 或生成独立的服务提供者来存放它们:
<?php
namespace App\Providers;
class AppServiceProvider extends ServiceProvider
{
/**
* 启动所有应用服务
*
* @return void
*/
public function boot()
{
view()->share('key', 'value');
}
/**
* 注册服务提供者
*
* @return void
*/
public function register()
{
//
}
}
## 视图composer
是当视图被渲染时的回调或类方法
如果你有一些数据要在视图每次渲染时都做绑定,可以使用视图 Composer 将逻辑组织到一个单独的地方。
首先要在服务提供者中注册视图 Composer,我们将会使用辅助函数 view 来访问 Illuminate\Contracts\View\Factory 的底层实现,记住,Laravel 不会包含默认的视图 Composer 目录,我们可以按照自己的喜好组织其路径,例如可以创建一个 App\Http\ViewComposers 目录:
<?php
namespace App\Providers;
use Illuminate\Support\Facades\View;
use Illuminate\Support\ServiceProvider;
class ComposerServiceProvider extends ServiceProvider
{
/**
* 在容器中注册绑定.
*
* @return void
* @author http://laravelacademy.org
*/
public function boot()
{
// 使用基于类的composers...
View::composer(
'profile', 'App\Http\ViewComposers\ProfileComposer'
);
// 使用基于闭包的composers...
View::composer('dashboard', function ($view) {});
}
/**
* 注册服务提供者.
*
* @return void
*/
public function register()
{
//
}
}
注:如果创建一个新的服务提供者来包含视图 Composer 注册,需要添加该服务提供者到配置文件 config/app.php 的 providers 数组中。
现在我们已经注册了 Composer,每次 profile 视图被渲染时都会执行 ProfileComposer@compose,接下来我们来定义该 Composer 类:
<?php
namespace App\Http\ViewComposers;
use Illuminate\View\View;
use Illuminate\Repositories\UserRepository;
class ProfileComposer
{
/**
* 用户仓库实现.
*
* @var UserRepository
*/
protected $users;
/**
* 创建一个新的属性composer.
*
* @param UserRepository $users
* @return void
*/
public function __construct(UserRepository $users)
{
// Dependencies automatically resolved by service container...
$this->users = $users;
}
/**
* 绑定数据到视图.
*
* @param View $view
* @return void
*/
public function compose(View $view)
{
$view->with('count', $this->users->count());
}
}
视图被渲染前,Composer 类的 compose 方法被调用,同时 Illuminate\View\View 实例被注入该方法,从而可以使用其 with 方法来绑定数据到视图。
注:所有视图 Composer 都通过服务容器被解析,所以你可以在 Composer 类的构造函数中声明任何你需要的依赖。
添加 Composer 到多个视图
你可以传递视图数组作为 composer 方法的第一个参数来一次性将视图 Composer 添加到多个视图:
View::composer(
['profile', 'dashboard'],
'App\Http\ViewComposers\MyViewComposer'
);
composer 方法接受 * 通配符,从而允许将一个 Composer 添加到所有视图:
view()->composer('*', function ($view) {
//
});
#### 视图创建器
视图创建器和视图 Composer 非常类似,不同之处在于前者在视图实例化之后立即失效而不是等到视图即将渲染。使用 creator 方法即可注册一个视图创建器:
View::creator('profile', 'App\Http\ViewCreators\ProfileCreator');