dongzao9044 2016-09-06 06:02
浏览 98
已采纳

Laravel 5.3 View Composer - 更改从控制器传递到视图的数据

Im getting a bit confused at how to work View Composers in Laravel and i thought i might ask some advice.

For example, my website has plans, in plans table i have the usual ID etc etc but i also have 'space_allowed' which is represented my a number, i have represented 'unlimited' as NULL so that i dont have to change any of my (count) functionalities.

So, in my controller i have something like this

$plans = Plan::where('is_active', 1)->get();
return view('pricing', ['plans' => $plans]);

Now when im in the view i just @foreach over the plans and spit out the details.

BUT, since im storing 'unlimited' space as NULL, the view then reflects that.

So i figure that since ill be referencing this all over the site, it would be a good idea to check if the value is null, and if it is, return 'unlimited' instead, and if the value isnt null, then just spit it out as normal in one place.

Hence the idea for the view composer.

So i have created the ComposerServiceProvider.php, added the boot and register methods and inside the boot method i have the following:

View::composer('*', function ($view) {
});

So i think im almost there.

But im lost on how to implement the code that goes in that closure to check if the storage_allowed is null

Any help would be greatly appreciated.

  • 写回答

3条回答 默认 最新

  • doubi8383 2016-09-06 06:08
    关注

    You can do this in view composer only by duplicating a lot of data, so just do this check in Blade template:

    @foreach ($plans as $plan)
        ....
        {{ empty($plan->space) ? 'Unlimited' : $plan->space }}
        ....
    @endforeach
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 电脑和power bi环境都是英文如何将日期层次结构转换成英文
  • ¥15 DruidDataSource一直closing
  • ¥20 气象站点数据求取中~
  • ¥15 如何获取APP内弹出的网址链接
  • ¥15 wifi 图标不见了 不知道怎么办 上不了网 变成小地球了
  • ¥50 STM32单片机传感器读取错误
  • ¥50 power BI 从Mysql服务器导入数据,但连接进去后显示表无数据
  • ¥15 (关键词-阻抗匹配,HFSS,RFID标签)
  • ¥50 sft下载大文阻塞卡死
  • ¥15 机器人轨迹规划相关问题