我正在通过Yii教程书,目前正在学习过滤器。过滤器通常可以应用于控制器,也可以仅应用于特定操作。
我正在研究的例子是创建一个新问题。每个问题都属于一个项目,因此我们添加了一个过滤器,以确保project_id
传递到issue/create
页面。由于issue/create
是唯一需要project_id
的网页,因此我们将过滤器应用于单个操作:
public function filters(){
return array(
'accessControl', // perform access control for CRUD operations
'projectContext + create',//check to ensure valid project context
);
}
我的问题是:如果过滤器仅适用于控制器中的单个操作,为什么不直接将filterProjectContext()
代码放入actionCreate()
函数?
答案 0 :(得分:5)
根据yii docs以及我对其他框架的经验,过滤器并不意味着与行动相结合。相反,过滤器允许您在达到任何操作之前访问PHP全局变量,例如$_REQUEST
值。例如,我参与了一个项目,如果使用特定值传递url参数,我们希望突出显示所有翻译文本。我们可以在控制器中完成此操作,但觉得在过滤器中实现业务规则更好。过滤器最终看起来像:
// Symfony code, but should demonstrate the idea
if ($context->getRequest()->getParameter('highlightTranslations') === 'y') {
// Tell translator API to highlight any subsequent translations
}
过滤器的优点在于无论请求的操作是什么,都将执行此代码。我的建议是你不要将过滤逻辑与动作逻辑混合在一起。