在控制器内调用控制器?

时间:2009-09-21 21:45:03

标签: php kohana

就推荐的最佳做法而言,这是推荐的吗?我有一个注释控制器+模型需要在项目和配置文件控制器中调用。注释控制器自动加载注释模型。

直接从项目和配置文件控制器调用注释控制器是否可以接受,或者是调用注释模型的“最佳实践”方式?

我问,因为在kohana中,视图不是单例类,所以如果我在另一个控制器中调用控制器,我最终会得到两个视图。另一方面,如果我只是调用模型,那么项目和配置文件控制器中会有重复的代码。

所有MVC专家都会提供帮助! =)

4 个答案:

答案 0 :(得分:6)

如果您使用Kohana 3,您可以从HMVC功能中受益。您可以在控制器中执行控制器。

http://forum.kohanaphp.com/comments.php?DiscussionID=2768

查看以上链接以获取一些示例

答案 1 :(得分:3)

一般来说,我会选择“胖模型”。

我不确定你真正担心重复的代码。

有几种方法可以做到这一点:

第一种方式: - 询问您的评论模型以返回一些评论。 - 将评论数据传递到您的视图中。 - 在视图中渲染注释,可能使用一些视图助手

第二种方式: - 意识到您的视图没有理由不能直接与您的模型对话。 - 编写一个视图助手,直接从模型中获取所需的数据,然后渲染它。

我更喜欢第二种方式。有些人在让他们的视图层与模型对话时会出现问题(以只读方式!),但我不是其中之一。

答案 2 :(得分:1)

我会说这取决于你的控制器返回的内容。

如果您的控制器可以返回DTO /模型,那么确定,调用控制器是一个好主意。

您的控制器为您的功能定义了严格的,记录在案的,并且有希望稳定的入口点。因此,只要不更改Controller方法的签名,就可以完全忽略Comment的实现,或者随意更改它。

但是,如果您的Controller无法返回原始数据,那么它肯定是有效的,因为您获得了html(或其他标记)作为回报。这意味着您必须将html直接传送到所需的视图中,或从中提取数据。这两个都是个坏主意。

管道原始html意味着如果更改“注释”视图,“配置文件”模块上的注释显示将不可避免地发生变化。这可能是你想要的,但我会追求灵活性。

现在,如果你想要数据,你将不得不从你的视图返回的标记中提取数据,这很重,反效果。

答案 3 :(得分:0)

如果您尝试调用静态方法,则可以直接调用该函数。例如:

class Controller_User extends Controller {
    public static function format_user($user){
        return array("data" => $user->getData());
    }
}

class Controller_Foo extends Controller {
    public function action_index(){
        $user = get_user_data_some_how();
        $user_data = Controller_User::format_user($user)
    }
}