建站教程

建站教程

Products

当前位置:首页 > 建站教程 >

WordPress获取显示分类文章数的4种方法(如何调用WordPress网站中文章的前5篇和后5篇?)

GG网络技术分享 2025-03-18 16:13 1


WordPress获取显示分类文章数的4种方法

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网站中文章的前5篇和后5篇?

  使用Wordpress建网站时,为了提高网站的PV值,可以给每篇文章添加相关文章,如何调用WordPress网站中文章的前5篇和后5篇?效果如下图:

如何调用WordPress网站中文章的前5篇和后5篇? (https://www.wpmee.com/) WordPress使用教程 第1张

  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