Products
GG网络技术分享 2025-03-18 16:13 1
WordPress在数据调用方面,和phpcms很不一样,在WP中,一个父分类下有多个层级的子分类,而且需要将一个父分类下所有子分类的文章数目进行统计, 在这里与大家分享获取显示分类文章数的具体方法。
WordPress获取显示分类文章数的几种方法:
方法1:将以下PHP代码放置在主题目录下的functions.php中:
然后在需要的地方调用该函数即可,该函数提供三种调用方式:
1.1 在主循环中调出该函数,且不提供参数,则返回第一个分类的文章数:
1.2 提供的参数为数字,且该数字为分类的ID号,则返回对应ID的分类的文章数:
1.3 提供分类的别名,则返回对应缩略名(别名)的分类文章数:
该函数对于含有子分类的分类,文章数统计上会有稍许误差。对于分类文章数为0的情况统计得也不是很好。
方法2:其实我们可以直接使用WordPress的内置函数wp_list_categories(),只是传递函数的时候注意一下就行了:
参数include的等号后面3改成你想要统计文章数的分类ID即可,最终输出形式为 分类名称(文章数) ,如 教程指南(20)
方法3:使用WordPress内置函数get_category_by_slug()
方法4:使用WordPress内置函数get_category
总结:方法一、三、四可以获取到单纯的文章数量,就代码量来说,方法一的代码是最多的,方法三、四的代码是最少的。就执行效率来说,方法一执行时间约为0.002秒,效率最高;方法四次之,执行时间约为0.004秒;方法三最差,执行时间约为0.008秒。执行效率之所以会有这么大的差异,原因在于方法一专注于一件事,就是查找文章数量,只执行一次数据库查询,而方法三和方法四的是WordPress内置函数,虽然只需一行代码,但是他们并不是专门为查询分类文章数而设计的,而是用于获取分类的全部信息!另外,这三种方法都不会统计子分类下的文章数。
使用Wordpress建网站时,为了提高网站的PV值,可以给每篇文章添加相关文章,如何调用WordPress网站中文章的前5篇和后5篇?效果如下图:
WordPress建网站时,如何调用WordPress网站中文章的前5篇和后5篇?下面分享一下调用方法和代码。
方法/步骤
1. 将以下的PHP代码放到自己网站模板的函数文件functions.php中;
function ztmao_get_post( $previous = true, $number = 1 ) { //global当前文章变量 $post 和数据库操作类wpdb
global $post, $wpdb;
if ( emptyempty( $post ) )
return null;
$current_post_date = $post->post_date;//当前文章的时间
$join = \'\';
$posts_in_ex_cats_sql = \'\';
//加入表
$join = \" INNER JOIN $wpdb->term_relationships AS tr ON p.ID = tr.object_id INNER JOIN $wpdb->term_taxonomy tt ON tr.term_taxonomy_id = tt.term_taxonomy_id\";
//获取当前文章所属分类,可以同属多个分类,如果是自定义的分类法,将category换成对应的分类法即可
$cat_array = wp_get_object_terms($post->ID, \'level\', array(\'fields\' => \'ids\'));
$join .= \" AND tt.taxonomy = \'level\' AND tt.term_id IN (\" . implode(\',\', $cat_array) . \")\";
//判断时间是大于还是小于
$op = $previous ? \'<\' : \'>\';
//排序
$order = $previous ? \'DESC\' : \'ASC\';
$where = $wpdb->prepare(\"WHERE p.post_date $op %s AND p.post_type = %s AND p.post_status = \'publish\' \", $current_post_date, $post->post_type);
$sort = \"ORDER BY p.post_date $order LIMIT 0, $number\";
$query = \"SELECT p.* FROM $wpdb->posts AS p $join $where $sort\";
$query_key = \'adjacent_post_\' . md5($query);
$result = wp_cache_get($query_key, \'counts\');
if ( false !== $result )
return $result;
$result = $wpdb->get_results(\"SELECT p.* FROM $wpdb->posts AS p $join $where $sort\");
if ( null === $result )
$result = \'\';
wp_cache_set($query_key, $result, \'counts\');
return $result;
}
2.使用以下的代码进行前5篇后5篇文章的调用。
<h4>前几篇文章</h4> <ul>
<?php
$preposts = v7v3_get_post(true,3);
foreach( $preposts as $postt ){
echo \'<li><a href=\"\'.get_permalink($postt->ID).\'\" title=\"\'.$postt->post_title .\'\">\'.$postt->post_title .\'</a></li>\';
};
?>
</ul>
<h4>后几篇文章</h4>
<ul>
<?php
$nextposts = ztmao_get_post(false,3);
foreach( $nextposts as $postt ){
echo \'<li><a href=\"\'.get_permalink($postt->ID).\'\" title=\"\'.$postt->post_title .\'\">\'.$postt->post_title .\'</a></li>\';
};
?>
</ul>
Demand feedback