Laravel 5.4 Blade 引入了组件和插槽的概念——但我看不出它们在传统的 @include 上添加了什么。据我了解,对于组件/插槽,您可以:
在模板组件-tpl.blade.php 中:
<div class='container'>
<h1>{{$slot1}}</h1>
<h2>{{$slot2}}</h2>
</div>
在页面模板中使用插槽,您可以:
@component('component-tpl')
@slot('slot1')
The content of Slot 1
@endslot
@slot('slot2')
The content of Slot 2
@endslot
@endcomponent
与旧版本相比,它提供了哪些功能:
@include('component-tpl',['slot1'=>'The content of Slot 1',
'slot2'=>"The content of Slot 2"])
使用完全相同的“component-tpl.blade.php”Blade 模板?
我错过了什么?感谢您提供任何见解。
克里斯
最佳答案
如前所述,没有功能差异我错了 - 请参阅 benjaminhull's answer有关变量作用域和传递 Blade 语法代码的详细信息。不过,以下内容仍然适用于基本用法。
如果一个插槽可以包含 HTML,那么使用一个组件将在你的 blade 文件中提供一个更清晰的语法。
@component('test')
<strong>This text has html</strong>
@endcomponent
对比
@include('test', ['slot' => '<strong>This text has HTML</strong>'])
同样,如果一个组件没有插槽,那么 include 可能是首选:
@include('test')
对比
@component('test')
@endcomponent
关于php - Laravel Blade - @slot/@component 与 @include 的优势?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44212318/
转自:spring.profiles.active和spring.profiles.include的使用及区别说明下文笔者讲述spring.profiles.active和spring.profiles.include的区别简介说明,如下所示我们都知道,在日常开发中,开发|测试|生产环境都拥有不同的配置信息如:jdbc地址、ip、端口等此时为了避免每次都修改全部信息,我们则可以采用以上的属性处理此类异常spring.profiles.active属性例:配置文件,可使用以下方式定义application-${profile}.properties开发环境配置文件:application-dev
我正在使用Rails3.2.3和Ruby1.9.3p0。我发现我经常需要确定某个字符串是否出现在选项列表中。看来我可以使用Ruby数组.includemethod:或正则表达式equals-tildematchshorthand用竖线分隔选项:就性能而言,一个比另一个好吗?还有更好的方法吗? 最佳答案 总结:Array#include?包含String元素,在接受和拒绝输入时均胜出,对于您的示例只有三个可接受的值。对于要检查的更大的集合,看起来Set#include?和String元素可能会获胜。如何测试我们应该根据经验对此进行测试
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它
我有以下代码,其中有一个小错误,case语句返回值“other”,即使第一个“when”语句评估为true并且应该返回“boats”。我已经关注这个很久了,一定是个小东西。CATEGORY_CLASSES={:boats=>[1,2,3,4,5,6],:houses=>[7,8,9,10],:other=>[11,12,13,14,15,16]}category_id=1category=casecategory_idwhenCATEGORY_CLASSES[:boats].include?(category_id);"boats"whenCATEGORY_CLASSES[:house
我使用以下钩子(Hook)来检查在执行includeFoo时执行包含的模块:moduleFoodefself.included(includer)putsincluderendendModule#include在模块中(通常使用它的地方)与在顶层的行为不同。在模块内部,self是模块,它是Module的一个实例.当我调用include,执行包含的模块是whatself是:moduleBarputsself#=>BarincludeFoo#=>includer:Barend在ruby脚本的顶层,self是main,它是Object的一个实例.当我调用include在顶层,包含的模块是
我有两个模型用户和事件。基数是一个用户有很多事件。当我查询数据库以提供所有用户及其相应事件时,它会返回正确的结果。示例语句:Users.find(:all,:include=>[:events])但是,我需要帮助的是根据条件为用户获取事件。我需要返回的每个用户只获取今天安排的事件(例如:CREATED_DATE=TODAY)。也就是说,我不希望所有事件都与用户关联。也就是说,我仍然需要在数据库中找到的所有用户,但对于今天没有安排事件的一些用户,他们不应该在HashMap中加载事件。有人可以帮我修改“Users.find(:all,:include=>[:events])”Rails语句
我试图理解include语句在多个Mixin中使用时的行为。也就是说,我有这些声明:classArticleDoubleIncludedModule将被包含在Article类中多少次?也就是说,由于DoubleIncludedModule的“后续”包含(首先在Article类中,然后在Article包含的AModule中类本身),将是Ruby自动处理的“双重包含”问题,还是DoubleIncludedModule(错误地)包含两次?当然,我想包含DoubleIncludedModule模块仅一次。我怎样才能以正确的方式做到这一点(也许通过使用一些RubyonRails方法)?
我知道include?是如何工作的,但是不太清楚将它与多维数组或散列一起使用(这可能与散列一起使用吗?)例如,假设我有一个看起来像这样的哈希:@user.badges=>[{:id=>1,:name=>'blahh',:description=>'blahblahblah'},{:id=>2,:name=>'blahh',:description=>'blahblahblah'}]我能像这样看看它里面有没有id为1的对象吗?if@user.badges.include?(:id=>1)#dosomethingend好像不行,这个方法怎么写好? 最佳答案
假设我想像这样访问散列的值:munsters={"Herman"=>{"age"=>32,"gender"=>"male"},"Lily"=>{"age"=>30,"gender"=>"female"},"Grandpa"=>{"age"=>402,"gender"=>"male"},"Eddie"=>{"age"=>10,"gender"=>"male"},"Marilyn"=>{"age"=>23,"gender"=>"female"}}我可以使用带有两个参数的#each:munsters.eachdo|key,value|puts"#{name}isa#{value["age"]
假设如下:defcreate_new_saltself.salt=self.object_id.to_s+rand.to_send为什么使用“self”更好。而不是实例变量“@salt”? 最佳答案 如果已定义,使用self.salt=将导致使用salt=方法。这对于确保使用salt=方法内的任何错误检查/转换很有用。然而,这意味着必须有一个明确的salt=方法(例如,可能由attr_accessor创建),这不一定是个好主意。总结:如果你有一个自定义的salt=方法,使用self.salt=;使用@salt=如果你确切地知道你想要