我使用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)
中。这不是一个好方法,我认为需要将html
与php class
分开。
编辑:(这是我的页面显示/打印线程注释)
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();
在我的页面中,线程注释用format_comment
显示并工作为true。如果我需要使用与php类不同的html来设计输出。
在这种情况下,我们如何将html代码从类中分离出来?!
发布于 2015-09-04 21:26:56
你是对的。
1)最简单的解决方案是将数组传递给模板。这个模板不包含逻辑,只包含html和php (例如,数组的前端)。
2)对于啤酒分离,使用模型-视图-控制器模式:
有了这层结构,每一层都有自己的责任。在模型和控制器中从不使用html。仅在模型中查询。
Laravel和CodeIgniter等框架实现了这种模式。
https://stackoverflow.com/questions/32409664
复制