【问题标题】:php class structure for presentation用于演示的 php 类结构
【发布时间】:2011-05-25 22:02:41
【问题描述】:

我需要有经验的开发人员对此提出建议。让我直接进入它。

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

在我目前的程序方法中,它是这样的:

$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'] }
}

面向对象的问题:

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

2.) 我想分开展示(使用 savant3 模板),那么我应该把显示方法放在哪里?我将需要显示很多东西(工作、cmets 等),我认为在模板中为它们中的每一个都创建一个方法不是一个好主意。

这个例子是用户和文章,但我会有用户+评论,用户+工作+需求。

我想将显示方法设为静态并让它们带一个参数,但它与过程方法没有什么不同。或者创建一个 setData($row) 方法,将 $data 设置为它得到的参数。

这个问题可能有一个通用的解决方案。

感谢任何建议。

谢谢你, 斯卡塞尔

【问题讨论】:

    标签: php database class structure presentation


    【解决方案1】:

    Article 类不应有加载方法或显示方法。

    我的建议是创建一个table gateway

    Class ArticleGateway {
    
        getArticles(){} // returns an array of article objects
        getArticlesByAuthor( Author $author ) {}
    
    }
    
    $articleGateway = new ArticleGateway() {}
    $articles = $articleGateway->getArticles();
    

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

    【讨论】:

    • 谢谢!我会考虑一下(这是我自己的项目)并回复你。我需要一些可以处理分页结果、有序结果、全文搜索和非全文搜索结果的东西,并且很快也会将 sphinx 添加为搜索引擎。它也需要计算结果。 Here is the link to the current page - 点击右侧的“详细搜索”。它需要发生在不止一页上......
    【解决方案2】:

    正如@galen 所说,

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

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

    【讨论】:

      猜你喜欢
      • 2011-02-06
      • 2012-01-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2018-10-01
      • 2013-09-30
      相关资源
      最近更新 更多