这是场景;在网站的管理部分,我有很多CRUD表,当执行某个操作(例如删除记录)时,需要显示成功/信息/错误消息。我相信每个人都熟悉这一点。
这通常涉及在<div class="alert alert-success">User updated</div>
或类似内容中包含的消息。
在我正在创建的当前Laravel应用程序中,我有一个配置文件:
<?php
return array(
'info' => array(
'start' => '<div class="callout callout-info"><h3><i class="icon-info-sign-sign"></i> Information</h3>',
'opening' => '<i class="icon-caret-right"></i> ',
'closing' => '<br>',
'end' => '</div>',
),
'success' => array(
'start' => '<div class="callout callout-success"><h3><i class="icon-ok-sign"></i> Success</h3>',
'opening' => '<i class="icon-caret-right"></i> ',
'closing' => '<br>',
'end' => '</div>',
),
'warning' => array(
'start' => '<div class="callout callout-warning"><h3><i class="icon-warning-sign"></i> Warning</h3>',
'opening' => '<i class="icon-caret-right"></i> ',
'closing' => '<br>',
'end' => '</div>',
),
'error' => array(
'start' => '<div class="callout callout-danger"><h3><i class="icon-remove-sign"></i> Warning</h3>',
'opening' => '<i class="icon-caret-right"></i> ',
'closing' => '<br>',
'end' => '</div>',
)
);
格式化程序类用于将MessageBag
的对象(存储数组,例如验证错误,例如无效电子邮件)呈现到可读HTML中。这并不完全是在Formatter类中存储HTML,但它确实在其中呈现。
formatter类只是使用配置选项呈现MessageBag对象,所以:
$formatter = new Formatter('success', $messageBag);
$html = $formatter->render();
然后从控制器传递到视图并显示。
return View::make('admin.template')->with('message', $html);
此方法允许我更新HTML及其在一个类中从整个管理部分呈现的方式。因此,伴随着DRY
原则。它减少了我模板中的所有foreach
循环。
所以这引出了一个问题......
在视图模板中重复自己而不是混淆业务层和表示层是否更好?反之亦然?
我的个人意见(目前)是将配置文件与类一起使用是一个很好的解决方案。我也认为在一个类中存储HTML是不好的做法,因此配置文件。
答案 0 :(得分:2)
这真是一个判断电话。
大多数时候,我更喜欢将HTML保留在类和配置文件之外。相反,我尽可能多地将HTML放在模板中。不同视图共享的模板可以存储在共享位置,并由模板引擎在正确的上下文中进行解析。
顺便说一句,在编写小型应用程序和扩展时,我对这个概念做了很多例外。虽然我认为两者都很重要,但我认为我重视务实思维而不是保持一致。
真正的问题是,需要花多少时间来分离所有不同的数据类型,这样做的回报是否足以证明您将投入的时间和精力?