3

我在 Drupal 中有一个带有一些评论的节点。有没有一种简单的方法来获取节点内每个评论的 CID?另外,有没有办法按各种参数、年表、评论的业力等对它们进行排序。谢谢。

4

3 回答 3

3

我想你应该检查 comment_render 函数。

但是如果您需要自己的排序参数,使用 sql 命令会更容易;

检查:http ://api.drupal.org/api/function/comment_render/6

您可以先进行查询,列出您需要订购的所有 cid;

$myquery = 'SELECT c.cid, c.pid, c.nid, c.subject, c.comment, c.format, c.timestamp, c.name, c.mail, c.homepage, u.uid, u.name AS registered_name, u.signature, u.picture, u.data, c.status FROM {comments} c INNER JOIN {users} u ON c.uid = u.uid WHERE c.nid
= %d ORDER BY c.uid ASC';

$myresult = db_query($myquery)

此查询存在于 comment_render 函数中。但我试图修改它以供我使用。

现在我们按照我们想要的顺序获得了节点 idcid

这是渲染工作;

while ($mycomments = mysql_fetch_row($myresult)){

foreach ($mycomment as $mycid)

comment_render($nid, $mycid)

}

我还没有测试过这个,但我希望它有帮助。

于 2009-03-25T02:45:19.663 回答
1

您可以使用以下函数在 drupal 7 中加载节点的所有注释:

comment_get_thread($node, $mode, $comment_per_page)

在此处查看文档:http: //api.drupal.org/api/drupal/modules%21comment%21comment.module/function/comment_get_thread/7

它还讨论了默认排序参数。然而,这并没有给你一个简单的方法来诉诸评论。我会为此使用视图。然后可以使用 hook_node_view 禁用默认评论显示并添加 views_embed_view('my_view', 'my_display');

于 2012-08-07T20:34:07.777 回答
0

更简单的解决方案:

$sql = "SELECT cid FROM {comments} WHERE nid=%d ORDER BY timestamp DESC";

$resource = db_query($sql, $node->nid);
while( $row = db_fetch_array( $resource ) ) {
  print comment_render( $node->nid, $row['cid'] );
}

我们的初始 SQL 查询只需要获取评论 ID (cid),因为 comment_render 的第二个参数将处理获取所有附加信息。

于 2009-06-17T00:11:25.783 回答