Laravel程序员PHP开发

laravel 基础教程 —— 视图

2016-05-14  本文已影响526人  Dearmadman

视图

视图为表现逻辑与应用逻辑的分离提供了便利,laravel 中所有的视图都被存储在 resources/views 目录下。

基础用法

一个简单的视图看起来是这样的:

<!-- View stored in resources/views/greeting.php -->

<html>
  <body>
    <h1>Hello, <?php echo $name; ?></h1>
  </body>
</html>

我们可以使用全局的帮助函数 view 来返回视图 resources/views/greeting.php 的渲染的结果:

Route::get('/', function () {
  return view('greeting', ['name' => 'James']);
});

你可以看到,view 方法接收的第一个参数是相对于目录 resources/views 的文件名。该方法也允许传递数组作为第二个参数,数组中的键值对会作为相应的变量传递到视图。上面的例子中就会输出 Hello, James

假如视图存在

如果你需要判断视图是否存在,那么你可以使用 exists 方法来进行验证,你可以通过使用无参数的全局帮助函数 view() 来进行链式操作,如果视图存在则会返回 true

if (view()->exists('email.customer')) {
  // 
}

当调用 view 方法而不传递任何参数时,会返回一个 Illuminate\Contracts\View\Factory 的实例,你可以访问该契约的任何方法。

视图数据

传递数据到视图

从上面的例子你就可以看出,你可以非常方便的使用一个数组作为数据来传递到视图:

return view('greetings', ['name' => 'Victoria']);

使用这种方法传递数据,$data 必须应该是键值对的形式,在视图中,你可以使用相应的‘键’来访问相应的数值。当然你可以使用 with 方法来传递额外的数据:

return view('greetings')->with('name', 'Victoria');

共享数据到所有视图

有时候,你可能需要共享一部分数据到所有的视图中,你可以使用视图工厂方法 share 来做到这件事情。通常情况下,你应该是在服务容器中的 boot 方法中去做数据共享操作。你可以在 AppServiceProvider 或者 独立生成一个分离的服务提供者来做这件事:

namespace App\Providers;

class AppServiceProvider extends ServiceProvider
{
  /**
   * Bootstrap any application services.
   *
   * @return void
   */
   public function boot()
   {
      view()->share('key', 'value');
   }

   /**
    * Register the service provider.
    *
    * @return void
    */
    public function register()
    {
      //
    }
}

视图 Composers

视图 composers (演奏者)就是当视图被渲染时会被触发的回调方法或者类的方法。如果你想要视图在每次被渲染时都自动的绑定一些数据到视图,那么视图 composer 就可以分离这些逻辑处理。

那么现在让我们在服务提供者中注册我们自己的视图 composers。我们将使用 view 帮助方法来返回一个 Illuminate\Contracts\View\Factory 契约的实现实例。laravel 中并没有提供一个默认的目录去管理这些视图 composers,你可以自主的按照自己的喜欢去管理这些,你当然也可以创建一个 App\Http\ViewComposers 目录:

<?php
namespace App\Providers;

use Illuminate\Support\ServiceProvider;

class ComposerServiceProvider extends ServiceProvider
{
  /**
   * Register bindings in the container.
   *
   * @return void
   */
   public function boot()
   {
      // Using class based composers...
      view()->composer(
        'profile', 'App\Http\ViewComposers\ProfileComposer'
      );

      // Using Closure based composers...
      view()->composer('dashboard', function ($view){
        //
      });
   }

   /**
    * Register the service provider.
    *
    * @return void
    */
    public function register()
    {
      //
    }
}

如果你创建了一个服务提供者来包含你所有的视图 composers 注册,你千万不要忘记在 config/app.php 文件中的 providers 数组中进行追加注册该提供者。

现在我们有了已经注册了的 composer,方法 ProfileComposer@compose 将在视图 profile 每次被渲染时自动执行。接着,我们来定义 ProfileComposer 类:

<?php
namespace App\Http\ViewComposers;

use Illuminate\View\View;
use App\Repositories\UserRepository;

class ProfileCompoer
{
  /**
   * The user repository implementation.
   *
   * @var UserRepository
   */
   protected $users;

   /**
    * Create a new profile composer.
    *
    * @param UserRepository $users
    * @return void
    */
    public function __construct(UserRepository $users)
    {
      // Dependencies automatically resolved by service container...
      $this->users = $users;
    }

    /**
     * Bind data to the view.
     *
     * @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');
上一篇下一篇

猜你喜欢

热点阅读