用于演示的php类结构

时间:2011-05-25 22:02:41

标签: php database class structure presentation

我需要经验丰富的开发人员提供建议。让我直截了当。

我有用户发帖,我需要显示文章列表并显示发布文章的用户。

在我的前瞻性方法中,它是这样的:

$result = mysql_getresult("SELECT users.*, articles.* 
                          FROM users JOIN articles ON users.id = articles.user_id
                          WHERE 1");
while($row = mysql_getrow($result)) {
    display_username($row);
    display_articletitle($row);
}

现在我想做OO方法

class User {
    protected $data;

    public function loadUserData($id) { $this->data = mysql_readstuff() }
    public function displayUserName() { echo $this->data['name'] }
}


class Article {
    protected $data;

    public function loadArticleData($id) { $this->data = mysql_readstuff() }
    public function displayArticleTitle() { echo $this->data['title'] }
}

OO的问题:

1。)这些类有自己的方法来加载自己的数据(以及许多其他方法),因此使用JOIN一次获取所有数据的快速mysql查询在这里并没有真正起作用。加载他们自己的数据非常适合许多其他方法(例如身份验证)。

2。)我想分开演示文稿(使用savant3模板),那么我应该在哪里放置显示方法?我需要展示很多东西(工作,评论等),我不认为在模板中为每个人制作一个方法是个好主意。

示例是用户和文章,但我将有用户+评论,用户+工作+要求。

我想让显示方法保持静态并让它们取一个参数,但是它与程序方法没什么不同。或者创建一个setData($ row)方法,将$ data设置为它所获得的参数。

这个问题可能有一个共同的解决方案。

感谢任何建议。

谢谢你, Skaccer

2 个答案:

答案 0 :(得分:1)

文章类不应该有加载方法或显示方法。

我的建议是创建一个table gateway

Class ArticleGateway {

    getArticles(){} // returns an array of article objects
    getArticlesByAuthor( Author $author ) {}

}

$articleGateway = new ArticleGateway() {}
$articles = $articleGateway->getArticles();

现在$articles包含一个文章对象数组。您可以在视图中迭代它并显示文章。

答案 1 :(得分:0)

正如@galen所说,

不要让你的类方法打印出你的数据,让它们返回一个数据数组,然后在你需要查看它们时处理它们:

我在开发应用程序时遇到过这种情况。我可以使用我的方法加载Android应用程序数据以及网站应用程序