我在 Drupal 中有一个带有一些评论的节点。有没有一种简单的方法来获取节点内每个评论的 CID?另外,有没有办法按各种参数、年表、评论的业力等对它们进行排序。谢谢。
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 函数中。但我试图修改它以供我使用。
现在我们按照我们想要的顺序获得了节点 id和cid。
这是渲染工作;
while ($mycomments = mysql_fetch_row($myresult)){
foreach ($mycomment as $mycid)
comment_render($nid, $mycid)
}
我还没有测试过这个,但我希望它有帮助。
您可以使用以下函数在 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');
更简单的解决方案:
$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 的第二个参数将处理获取所有附加信息。