【问题标题】:separate html from php comments class将 html 与 php 注释类分开
【发布时间】:2015-12-01 07:08:14
【问题描述】:

我发现这个类用于使用 php 和 MySQL 进行线程注释:

<?php
class Threaded_comments
{

public $parents  = array();
public $children = array();

/**
 * @param array $comments
 */ 
function __construct($comments)
{
    foreach ($comments as $comment)
    {
        if ($comment['parent_id'] === NULL)
        {
            $this->parents[$comment['id']][] = $comment;
        }
        else
        {
            $this->children[$comment['parent_id']][] = $comment;
        }
    }
}

/**
 * @param array $comment
 * @param int $depth
 */ 
private function format_comment($comment, $depth)
{
    for ($depth; $depth > 0; $depth--)
    {
        echo "\t";
    }

    echo $comment['text'];
    echo "\n";
}

/**
 * @param array $comment
 * @param int $depth
 */ 
private function print_parent($comment, $depth = 0)
{
    foreach ($comment as $c)
    {
        $this->format_comment($c, $depth);

        if (isset($this->children[$c['id']]))
        {
            $this->print_parent($this->children[$c['id']], $depth + 1);
        }
    }
}

public function print_comments()
{
    foreach ($this->parents as $c)
    {
        $this->print_parent($c);
    }
}

}

这适用于这个数组:

$comment = array(  array('id'=>1, 'parent_id'=>NULL,   'text'=>'Parent'),  
                    array('id'=>2, 'parent_id'=>1,      'text'=>'Child'),  
                    array('id'=>3, 'parent_id'=>2,      'text'=>'Child Third level'),  
                    array('id'=>4, 'parent_id'=>NULL,   'text'=>'Second Parent'),  
                    array('id'=>5, 'parent_id'=>4,   'text'=>'Second Child')  
                );  

结果:

$tc = new Threaded_comments($comment);
$tc->print_comments();

结果是:

Parent
    Child
        Child Third level
Second Parent
    Second Child

这确实有效但是对于定义注释列表(html),我需要将所有 html 代码添加到private function format_comment($comment, $depth)。这不是好方法,我认为需要将htmlphp class 分开。

编辑:(这是我的 show/print 线程评论页面)

function _comments_($id,$type){
    $DB_QUERY = mySqli::f("SELECT id,user,email,message,timestamp,parent_id,rfield_1,rfield_2,rfield_3,rfield_4,rfield_5 FROM " . NEWS_COMMENTS . " LEFT JOIN " . NEWS_REVIEWS . " ON " . NEWS_COMMENTS . ".id = " . NEWS_REVIEWS . ".cid WHERE 
    pid = ? AND type = ? AND approved = 1 ORDER BY timestamp DESC LIMIT 12", $id, $type);

        foreach($DB_QUERY as $row){
         $commentdata[] = $row;
        }
    return $commentdata;
}
$comments_list = _comments_('125','book');
foreach($comments_list as $row){
        $comments[] = array(
        'id' => $row['id'],
        'parent_id' => $row['parent_id'],
        'name' => $row['user'],
        'text' => $row['message'],
        'datetime' => $row['timestamp']
        );
        }

        $tc = new Threaded_comments($comments);
        $tc->print_comments();

在我的页面中,线程 cmets 显示为 format_comment 并且工作正常。如果我需要使用与 php 类分开的 html 来设计输出。

在这种情况下,我们如何将 html 代码与类分开?!

【问题讨论】:

    标签: php html mysql


    【解决方案1】:

    你是对的。

    1) 最简单的解决方案是将数组传递给模板。此模板不包含逻辑,而仅包含 html 和 php(例如您的数组的 foreach)。

    2)为了更好的分离,使用模型-视图-控制器模式:

    有了这个层结构,每一层都有自己的职责。永远不要在模型和控制器中使用 html。仅限模型中的查询。

    Laravel 和 CodeIgniter 等框架都有这种模式的实现。

    【讨论】:

    • 你也是。 MVC 工作得很好。但我在项目工作,需要自定义这个类。所以我需要将 html 代码从类中分离出来
    • 我稍微更新了我的答案。请参阅解决方案 1。使用您的 html 创建一个 .php 模板并将您的数组传递给他们。此模板仅包含 html 和简单的 foreach/if-php。
    猜你喜欢
    • 2010-09-05
    • 2015-12-19
    • 2022-01-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-02-18
    • 2015-08-07
    • 2011-08-12
    相关资源
    最近更新 更多