我需要经验丰富的开发人员提供建议。让我直截了当。
我有用户发帖,我需要显示文章列表并显示发布文章的用户。
在我的前瞻性方法中,它是这样的:
$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
答案 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应用程序数据以及网站应用程序