duanliang1019
duanliang1019
2016-10-12 06:25
浏览 54
已采纳

在Laravel的刀片模板功能中使用Handlebars数据

I want to use Handlebars data (i.e. {{ id }}) as a parameter in Laravel helper function on .blade template view.

I know about escaping Handlebars brackets when using .blade.php extension like @{{#each users}} or @{{ name }} and that works perfectly.

The problem comes when I want to use @{{ id}} within Laravel's helper function because of nested double curly brackets:

<a href="#" class="btn btn-xs btn-warning" data-route="{{ route('admin.membership.toggle-show-hide', ['id' => @{{ id }}]) }}">
    Hide
</a>

I know this can't work because helper function route doesn't expect curly bracket in parameters array but I still need to be able to pass data from Handlebars contex into Laravel's helper function on blade template view somehow.

I tried different ways to achieve this, but without success.

Does anyone knows some workaround or has any idea for this? Thank you all in advance.

EDIT

The alternative (which I currently use) is to write a Handlebars helper which will accept needed parameter and generate route for some action:

Handlebars.registerHelper("mmbrshpToggleShowHideRoute", function(id) {
    return APP_URL + '/admin/membership/' + id + '/toggleShowHide';
});

Using this, I can generate route string in Handlebars template (with .blade.php extension) for each item in Handlebars JSON context retrieved from Laravel's controller:

<a href="#" class="btn btn-xs btn-success" data-route="{{ mmbrshpToggleShowHideRoute id }}">
    Hide
</a>

I don't like this approach because I'm actually hardcoding the route URL in Handlebars helper function. This works and provides reusabillity throughout the views and templates, but it would be nicer if there was possibility to generate route using Laravel's route helper function and just pass an id parameter from Handlebars context.

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

3条回答 默认 最新

  • douduan5086
    douduan5086 2016-10-12 09:46
    已采纳

    If you really need "bulletproof" solution for changing routes on frontend than most convenient solution is to make an accessor for route in your model. Something like this:

    public function getRouteAttribute()
    {
        return route('admin.membership.toggle-show-hide', ['id' => $this->id]);
    }
    

    Then you need to make sure that accessor is always available (even if you return JSON response) in your object instances using $appends property like this:

    protected $appends = ['route'];
    

    That should be it.

    点赞 评论
  • dou426098
    dou426098 2016-10-12 07:16

    In fact you can't use both JS and PHP variables/functions at the same time as JS variables may change over time during the PHP session.

    When JS is involved I don't use routes, I use plain string routes like data-route="'/admin/membership/toggle/' + id"

    点赞 评论
  • dpztth71739
    dpztth71739 2016-10-12 07:30

    You can use this sample code.

    <a href=".URL::route('admin.membership.toggle-show-hide',[$id])." class="btn-blue">Hide</a>
    
    点赞 评论

相关推荐