使用wordpress程序自己建站的朋友们,经常会需要在首页或者分类页调用置顶文章,要实现单独添加置顶文章调用模块方法很多,可以用代码实现也可以用插件来实现。目前大部分主题都可以实现首页显示置顶文章功能了,但是博主本人目前用主题置顶文章和最新文章混在一起,难免有点美中不足,所以,用代码给首页添加一个单独的wordpress置顶文章模块。
一、置顶模块效果如图:
二、wordpress置顶模块代码:
1、PHP代码:
<?php $query_post = array( 'posts_per_page' => 10, 'post__in' => get_option('sticky_posts'), 'caller_get_posts' => 1 ); query_posts($query_post); ?> <?php while(have_posts()):the_post(); ?> <div class="most-comment-posts"> <ul> <li> <a href="<?php%20the_permalink();%20?>"> <?php the_title(); ?> </a> <span class="sticky-icon">置顶</span> </li> </ul> </div> <?php endwhile; ?> <?php wp_reset_query(); ?>
2、CSS代码:
温馨提示: 隐藏内容需要 回复评论 后才能查看, 评论后请 刷新 !.
上面这段wordpress调用置顶文章代码来自CSDN博客文章,原来的代码有图片,但是没有CSS样式,看上去不够美观,所以楚狂人自己进行了一些适合自己的修改。下面贴出原文代码,大家可以根据自己的需求进行个性化修改:
<?php $query_post = array( 'posts_per_page' => 10, 'post__in' => get_option('sticky_posts'), 'caller_get_posts' => 1 ); query_posts($query_post); ?> <?php while(have_posts()):the_post(); ?> <div class="swiper-slide"> <a href="<?php%20the_permalink();%20?>"> <img src="<?php%20the_post_thumbnail_url(%20'full'%20);%20?>" alt="<?php the_title(); ?>"> <div class="shadow"> <?php the_title(); ?> </div> </a> </div> <?php endwhile; ?> <?php wp_reset_query(); ?>
参数用一个数组的形式放在$query_post中,关键的参数为'post__in' =>get_option('sticky_posts')和'caller_get_posts' => 0。
'post__in' => get_option('sticky_posts')确定了该 LOOP 调用的是置顶文章列表。
'caller_get_posts'的作用是排除非指定性文章,即除了置顶文章之外,不显示其他的文章。
'posts_per_page' => 10,控制文章的数量
不添加的情况下,如果置顶文章条目不足'posts_per_page'规定的值,会用最新文章替补完整。
三、另一段置顶文章调用代码
<?php $args = array( 'posts_per_page' => -1, 'post__in' => get_option( 'sticky_posts' ) ); $sticky_posts = new WP_Query( $args ); while ( $sticky_posts->have_posts() ) : $sticky_posts->the_post();?> <li> <a href="<?php%20the_permalink()%20?>"><?php the_title(); ?></a> </li> <?php endwhile; wp_reset_query();?>
这段代码同样是调用置顶文章,但是这段代码显示的文章含有文章的内容,搞得页面都错位了,看上去修改起来要麻烦很多,所以我最终采用了第一段代码,但是这段代码是可以实现调用置顶文章的,有兴趣的朋友可以自己试试。
四、第三段置顶文章调用代码:
这款代码和上面的代码效果类似,都修改都有点麻烦,但是也许有朋友需要呢?一并转载分享在这里:
<?php if (have_posts()) : ?> <p>文章列表如下</p> <ul> <?php while (have_posts()) : the_post(); if (is_sticky()): global $more; // 设置全局变量$more $more = 1; ?> <li> <h2>[置顶]<a href="<?php%20the_permalink();%20?>" title="<?php the_title(); ?>" rel="bookmark"><?php the_title(); ?></a><h2/> <p><?php the_content(); ?></p> </li> <?php else: global $more; $more = 0; ?> <li> <h2><a href="<?php%20the_permalink();%20?>" title="<?php the_title(); ?>" rel="bookmark"><?php the_title(); ?></a><h2/> <p><?php the_content('阅读更多'); ?></p> </li> <?php endif; ?> <?php endwhile; ?> </ul> <?php else: ?> <h2>没有找到更多文章</h2> <?php endif; ?>
补充修改后置顶代码:
这段代码是按照上面的代码修改的,之所以要费劲的修改这段wordpress置顶文章调用代码,是因为这款代码可以实现所有置顶文章为一个模块,而本文最开始的那段代码显示的是每篇文章为一个模块,美观度各有不同。
温馨提示: 隐藏内容需要 回复评论 后才能查看, 评论后请 刷新 !.
代码说明:
wordpress置顶文章有两个常用的函数
is_sticky():判断文章是否是置顶的,是就返回true,不是就返回false
get_option('sticky_posts'): 获取置顶文章ID,返回包含各置顶文章ID的数组
首页展示文章时,如果是置顶文章就全文输出
方法简介:在loop循环时,通过 is_sticky()判断是否是置顶文章
是的话就设置全局变量$more=1;然后调用 the_content();就是全文输出了
否则不是置顶文章的话就设置全局变量 $more=0;然后调用 the_content('更多...');就是截取<--more-->标签后的输出
以上文章中原代码来自:https://blog.csdn.net/weixin_30517001/article/details/101390731,我只是修改并添加了CSS样式,如果您觉得文章有用,欢迎收藏分享,谢谢。
另外,以前的文章中楚狂人分享过两款插件,可以实现分类文章置顶,有兴趣的朋友可以移步阅读。
发布时间: 阅读(250)
五、排除置顶文章的代码:
如果想调用排除置顶文章的分类所有文章怎么操作?
<?php $query_post = array( 'category__in' => array(get_query_var('cat')),//如果是栏目调用,注意这行要加,否则会调用全站所有文章 'posts_per_page' => 5, 'post__not_in' => get_option('sticky_posts'),//排除置顶 'caller_get_posts' => 1 ); query_posts($query_post); ?> <?php while(have_posts()):the_post(); ?> <div class="item wow zoomIn"> <div class="img-box"> <img src="<?php%20the_post_thumbnail_url(%20'full'%20);%20?>" alt="<?php the_title(); ?>"> </div> <div class="text"> <div class="title"> <h3> <?php the_title(); ?> </h3> </div> <div class="description"> <p> <?php the_excerpt(); ?> </p> </div> <div class="more"> <a href="<?php%20the_permalink();%20?>">Read More</a> </div> </div> </div> <?php endwhile; ?> <?php wp_reset_query(); ?>