美文网首页Laravel程序员PHP开发
laravel 基础教程 —— 视图

laravel 基础教程 —— 视图

作者: Dearmadman | 来源:发表于2016-05-14 11:50 被阅读526次

    视图

    视图为表现逻辑与应用逻辑的分离提供了便利,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');
    

    相关文章

      网友评论

      • MakingChoice:把laravel学院的文章粘贴过来,没有干货呀。
        Dearmadman:@MakingChoice 事实上没有比这最干的干货了, :blush: 抱歉,这不是贴学院的,是手工翻译的

      本文标题:laravel 基础教程 —— 视图

      本文链接:https://www.haomeiwen.com/subject/mqimrttx.html