萨龙网络
登录
首页-WordPress文章-WordPress-正文

WordPress 自定义的评论查询类 WP_Comment_Query 参考文档和使用实例

萨龙龙萨龙龙
WordPress
7年前
0
0
1.71W
WordPress 获取评论所有主题都是使用wp_list_comments()函数,获取每篇文章的评论是相当的方便实用,唯一的不足是不能通过自定义值来获取评论,不过我们可以通过评论查询类WP_Comment_Query()来单独获取有自定义值的评论。 WP_Comment_Query()的用法:
wp_list_comments( array( 'callback' => 'salong_comment','type'=>'comment' ) );
其中salong_comment为评论的模版函数,自己可以写个。 本文最重要的还是介绍wp_list_comments()函数的使用与实例。

一、描述

WP_Comment_Query是一个类,定义在 wp-includes/class-wp-comment-query.php 文件中,允许查询WordPress数据库表“wp_comments”和“wp_commentmeta”,这个类是在WordPress3.1版本中引入的。

二、使用

$args = array(
   // args here
);

// The Query
$comments_query = new WP_Comment_Query;
$comments = $comments_query->query( $args );

// Comment Loop
if ( $comments ) {
	foreach ( $comments as $comment ) {
		echo $comment->comment_content;
	}
} else {
	echo 'No comments found.';
}

三、默认参数

$args = array(
    'author_email'              => '',    
    'author_url'                => '',
    'author__in'                => '',
    'author__not_in'            => '',
    'include_unapproved'        => '',
    'fields'                    => '',
    'ID'                        => '',
    'comment__in'               => '',
    'comment__not_in'           => '',
    'karma'                     => '',
    'number'                    => '',
    'offset'                    => '',
    'no_found_rows'             => true,
    'orderby'                   => '',
    'order'                     => 'DESC',
    'parent'                    => '',
    'parent__in'                => '',
    'parent__not_in'            => '',
    'post_author__in'           => '',
    'post_author__not_in'       => '',
    'post_id'                   => 0,
    'post__in'                  => '',
    'post__not_in'              => '',
    'post_author'               => '',
    'post_name'                 => '',
    'post_parent'               => '',
    'post_status'               => '',
    'post_type'                 => '',
    'status'                    => 'all',
    'type'                      => '',
    'type__in'                  => '',
    'type__not_in'              => '',
    'user_id'                   => '',
    'search'                    => '',
    'hierarchical'              => false,
    'count'                     => false,
    'cache_domain'              => 'core',
    'meta_key'                  => '',
    'meta_value'                => '',
    'meta_query'                => '',
    'date_query'                => null, // See WP_Date_Query
    'update_comment_meta_cache' => true,
    'update_comment_post_cache' => false,
);

四、参数说明

1、属性 $status (字符串) (可选) 值返回指定状态的评论 'hold' – 未通过审核的评论 'approve' – 已审核的评论 'spam' – 被标记未垃圾的评论 'trash' – 回收站中的评论 默认: None $orderby (字符串) (可选) 设置排列评论数据使用的字段 默认: comment_date_gmt $order (字符串) (可选) 排列 $orderby 的方法,可用值: 'ASC' – 升序 (从低到高) 'DESC' – 降序 (从高到低) 默认: DESC $number (整数) (可选) 返回的评论数量,留空返回所有评论。 默认: unlimited $offset (整数) (可选) 偏移的评论数量,必须和 $number 参数一起使用 默认: 0 $post_id (整数) (可选) 只返回指定 ID 文章的评论。 默认: None $user_id (整数) (可选) 只返回指定 ID 用户的评论。 默认: None $count (整数) (可选) 只返回评论的总数量。 默认: None $type__in (数组) (可选) 允许指定评论类型 默认: None $type__not_in (数组) (可选) 允许指定排除的评论类型 默认: None $meta_key (字符串) (可选) 自定义评论元数据 key。 默认: None $meta_value (字符串) (可选) 自定义评论元数据值。 默认: None $meta_query (数组) (可选) 高级元数据查询参数 (从 3.5 版开始可用)。 默认: None $fields (字符串) (可选) 指定返回的字段 ( 从4.0版本开始可用 )。 'ids' – 评论 ID '*' – 所有评论字段 默认: * 2、自定义字段参数 显示包含某个自定义字段的评论 meta_key (字符串) – 自定义字段key meta_value ( 字符串) – 自定义字段值 meta_query (数组) – 自定义字段参数 (从 3.5 版开始可用) key (字符串) -自定义字段key value (字符|数组) – 自定义字段值 (注意: 数组支持只限在以下对比方法中使用: 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN', 'EXISTS' 或 'NOT EXISTS') compare (字符) – 数据对比方法 '=', '!=', '>', '>=', '<', '<=', 'LIKE', 'NOT LIKE', 'IN', 'NOT IN', 'BETWEEN', 'NOT BETWEEN', 'EXISTS', 和 'NOT EXISTS'。 默认为 '='。 type (字符) – 自定义字段类型,可用的值有 'NUMERIC', 'BINARY', 'CHAR', 'DATE', 'DATETIME', 'DECIMAL', 'SIGNED', 'TIME', 'UNSIGNED'。 默认值为 'CHAR'。 3、获取特色评论
$comment_query = new WP_Comment_Query( array( 'meta_key' => 'featured', 'meta_value' => '1' ) );
4、多个元数据查询处理方法
$args = array(
    'meta_query'      => array(
        'relation'    => 'AND',
        array(
            'key'     => 'featured',
            'value'   => '1'
        ),
        array(
            'key'     => 'buried',
            'value'   => '1',
            'type'    => 'numeric',
            'compare' => '!='
        )
    )
 );
$comment_query = new WP_Comment_Query( $args );

五、返回值

(数组) 包含以下索引键的评论字段(如果没有评论,返回空数组): comment_ID (整数) 评论 ID comment_post_ID (整数) 评论所在的文章/页面 comment_author (字符串) 评论者的名称 comment_author_email (字符串) 评论者的电子邮件 comment_author_url (字符串) 评论者的链接 comment_author_IP (字符串) 评论者的 IP comment_date (字符串) 评论日期时间 (YYYY-MM-DD HH:MM:SS) comment_date_gmt (字符串) 评论的 GMT 日期时间 (YYYY-MM-DD HH:MM:SS) comment_content (字符串) 评论内容 comment_karma (整数) 评论来源 comment_approved (字符串) 评论审核状态 (0, 1 或 “spam”) comment_agent (字符串) 评论者的客户端信息 (浏览器, 操作系统,等) comment_type (字符串) 评论类型 (pingback|trackback), 普通评论为空 comment_parent (字符串) 评论的父级评论 ID,顶级评论为 0 user_id (整数) 如果评论者已注册,返回评论者的 用户ID

六、实例

获取当前文章下被点赞的评论,并按点赞数量反向排序
$args = array(
    'post_id'         => $post->ID,
    'meta_query'      => array(
        array(
            //获取有 like 自定义值的且值不为0的评论
            'key'     => 'like',
            'value'   => '0',
            'compare' => '!='
        )
    ),
    // 按钮自定义值排序
    'orderby'         => 'meta_value_num',
);
$comments_query  = new WP_Comment_Query;
$popularcomments = $comments_query->query( $args );
foreach ( $popularcomments as $comment ) {
    echo $comment->comment_content;
}
标签:
本文原创,作者:萨龙龙,其版权均为萨龙网络所有。
如需转载,请注明出处:https://salongweb.com/wp-comment-query.html
萨龙龙

萨龙龙

侠客
一个平平常常的人,热爱生活、旅行和摄影,骑行去过西藏,一直计划再去。14年从江西骑行来到大理,现栖居于洱海边,食人间烟火,过简单生活,做简约设计!
1342.26M456.70W3.85W
分享:
让 WordPress 菜单图像描述支持 HTML 标签
让 WordPress 菜单图像描述支持 HTML 标签上一篇
更新至 WordPress5.0版本后古腾堡(Gutenberg)编辑器发布与更新失败的解决方法(只对萨龙网络主题测试)下一篇
更新至 WordPress5.0版本后古腾堡(Gutenberg)编辑器发布与更新失败的解决方法(只对萨龙网络主题测试)
相关文章
总数:107

WordPress 添加菜单项目描述

WordPress能够在自定义菜单中存储每个菜单项的描述,默认情况下,这些描述不会显示在前端菜单中,需要为相应的菜单增加显示描述的功能。 一…
萨龙龙萨龙龙
WordPress
7年前
0
0
1.37W
0

WordPress强大好用的分页插件WP-PageNavi使用

相信使用Wordpress的朋友都对WP-PageNavi分页插件不陌生,很多博客对它也有很多介绍,之前也使用过代码来实现分页,但不够人性化,使…
萨龙龙萨龙龙
WordPress
10年前
0
0
2.47W
0

WordPress获取优酷视频缩略图

很多网站的视频都是来自在线视频网站,这样即节省网站空间也带来更高的访问速度,优酷视频是使用较多的。在添加视频文章时我们都想直接获取视频中的缩略图…
萨龙龙萨龙龙
WordPress
9年前
0
0
1.25W
0

WordPress 插入页面函数 wp_insert_post

萨龙网络已经开发了很多WordPress主题,LensNews主题要创建的页面较多,所以导致很多用户来咨询如何设置用户中心,在最新上线的…
萨龙龙萨龙龙
WordPress
8年前
0
0
2.14W
0

WordPress一行代码允许重复评论的功能

默认情况下WordPress是不允许重复的评论提交,主要是为了防止垃圾评论。有些情况下又需要重复评论,最近用户需要在MNewsPro主题上定制…
萨龙龙萨龙龙
WordPress
1年前
1
1
7.51K
0

禁用 WordPress 裁剪功能包括自动生成的 768 像素图片

WordPress媒体库是很强大、管理媒体相当方便,如果媒体多就给数据库增加了压力,而且很多媒体是不需要上传到媒体库,上传的图片会增加很多无用…
萨龙龙萨龙龙
WordPress
8年前
0
0
1.29W
0

WordPress获取多个角色的用户列表并分页

在WordPress按角色获取可分页的用户列表并显示最新文章这篇文章中我们已经介绍了获取单个角色的用户列表,如果想获取多个角色的用户列表呢,ge…
萨龙龙萨龙龙
WordPress
9年前
0
0
9.68K
0

WordPress多站点社区动态中获取自定义文章类型更新

萨龙网络使用Buddypress社区已经很长一段时间,在社区首页动态中可能获取整个网站的最新文章、用户注册,用户动态内容,而自定义文章类型的发布…
萨龙龙萨龙龙
Buddypress, WordPress
9年前
0
0
1.18W
0

WordPress 限制上传媒体的文件类型

MNews和LensNews主题都有前台投稿的功能,用户可以上传图片等文件,管理员是不希望用户上传任意的媒体文件,这时我们可以对用户上传的…
萨龙龙萨龙龙
WordPress
7年前
0
0
1.22W
0

删除或失效WordPress文章中的图像大小属性

默认情况下,WordPress会将图像元素width和height属性添加到图像元素中。这些属性会影响CSS宽度和高度属性,图片延迟加载时默认图…
萨龙龙萨龙龙
WordPress, 前端资讯
6年前
0
0
1.16W
0

WordPress 从不需要的页面禁用 WooCommerce 样式和脚本

WooCommerce在每个页面上加载三个核心CSS样式表,并在WordPress站点上安装时发布。可以通过从不需要它的页面和内容中删除样式和…
萨龙龙萨龙龙
WooCommerce
6年前
0
0
1.76W
0

WordPress 功能函数—— add_clean_index(向指定的表添加索引)

描述 向指定的表添加索引。 用法 add_clean_index(string$table,st…
萨龙龙萨龙龙
WordPress Functions
6年前
0
0
9.56K
0
评论表单游客 您好,欢迎参与讨论。
请输入昵称
请输入邮箱
请输入网址
0 / 0
评论列表
总数:0
萨龙网络
没有相关内容