我正在阅读Laravel Blade文档,我不知道如何在模板中分配变量以供以后使用。我不能使用{{$old_section = "whatever"}},因为这将会返回"whatever",而我不想这样做。
我知道我可以做<?PHP $old_section = "whatever";>,但这并不优雅。
在Blade模板中是否有更好、更优雅的方式来做到这一点?
我正在阅读Laravel Blade文档,我不知道如何在模板中分配变量以供以后使用。我不能使用{{$old_section = "whatever"}},因为这将会返回"whatever",而我不想这样做。
我知道我可以做<?PHP $old_section = "whatever";>,但这并不优雅。
在Blade模板中是否有更好、更优雅的方式来做到这一点?
当前回答
我不认为你可以——但是,这种逻辑可能应该在你的控制器中处理,并传递到已经设置好的视图中。
其他回答
我将扩展@Pim给出的答案。
将此添加到AppServiceProvider的引导方法中
<?php
/*
|--------------------------------------------------------------------------
| Extend blade so we can define a variable
| <code>
| @set(name, value)
| </code>
|--------------------------------------------------------------------------
*/
Blade::directive('set', function($expression) {
list($name, $val) = explode(',', $expression);
return "<?php {$name} = {$val}; ?>";
});
这样就不会暴露编写任何php表达式的能力。
你可以像这样使用这个指令:
@set($var, 10)
@set($var2, 'some string')
在Blade模板引擎中可以通过以下方式设置变量: 1. 通用PHP块 设置变量:<?php $hello = " hello World!";? > 输出:{{$你好}} 2. Blade PHP块 设置变量:@php $hello = " hello World!";@endphp 输出:{{$你好}}
简单的方法
如果你想定义多个变量,请使用blade指令的完整形式:
@php
$i = 1;
$j = 2;
@endphp
如果你只想定义一个变量,你也可以使用一个PHP语句:
@php($i = 1)
更高级的:添加一个' define '标签
如果你想使用自定义标签并使用@define而不是@php,可以像这样扩展Blade:
/*
|--------------------------------------------------------------------------
| Extend blade so we can define a variable
| <code>
| @define $variable = "whatever"
| </code>
|--------------------------------------------------------------------------
*/
\Blade::extend(function($value) {
return preg_replace('/\@define(.+)/', '<?php ${1}; ?>', $value);
});
然后做以下其中一项:
快速解决方案:如果您很懒,可以将代码放在AppServiceProvider.php的boot()函数中。
更好的解决方案: 创建自己的服务提供者。关于Laravel 5中如何扩展刀片,请参阅https://stackoverflow.com/a/28641054/2169147。这样做会有更多的工作,但这是一个关于如何使用Providers的很好的练习:)
完成以上修改后,您可以使用:
@define $i = 1
定义一个变量。
laravel文档https://laravel.com/docs/5.8/blade#php 你可以这样做:
@php
$my_variable = 123;
@endphp
分配变量刀片模板,这里是解决方案
我们可以使用<?刀片页面中的PHP ?>标记
<?php $var = 'test'; ?>
{{ $var }
OR
我们可以用特殊的语法使用刀片注释
{{--*/ $var = 'test' /*--}}
{{ $var }}