发表日期:2013-05-30 文章作者:爱永设计 浏览次数:16768 次
WordPress有原生的文章置顶功能,不过只支持在首页让置顶文章在顶部显示,其他如分类页、标签页、作者页和日期页等存档页面,就没法让 置顶文章在顶部显示了,只能按默认的顺序显示。有很多网友早前向我问过怎么解决这样的问题,当时查阅了一些没有解决就被搁置了。现在参考wp- includes/query.php中首页置顶的代码,稍微修改一下,可以让分类页、标签页、作者页和日期页等存档页面也能像首页一样在顶部显示其范围 内的置顶文章。把下面的代码放到当前主题下的functions.php中就可以了:
add_filter(‘the_posts’, ‘putStickyOnTop’ );
function putStickyOnTop( $posts ) {
if(is_home() || !is_main_query() || !is_archive())
return $posts;
global $wp_query;
$sticky_posts = get_option(‘sticky_posts’);
if ( $wp_query->query_vars[‘paged’] <= 1 && is_array($sticky_posts) && !empty($sticky_posts) && !get_query_var(‘ignore_sticky_posts’) ) { $stickies1 = get_posts( array( ‘post__in’ => $sticky_posts ) );
foreach ( $stickies1 as $sticky_post1 ) {
// 判断当前是否分类页
if($wp_query->is_category == 1 && !has_category($wp_query->query_vars[‘cat’], $sticky_post1->ID)) {
// 去除不属于本分类的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
if($wp_query->is_tag == 1 && has_tag($wp_query->query_vars[‘tag’], $sticky_post1->ID)) {
// 去除不属于本标签的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
if($wp_query->is_year == 1 && date_i18n(‘Y’, strtotime($sticky_post1->post_date))!=$wp_query->query[‘m’]) {
// 去除不属于本年份的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
if($wp_query->is_month == 1 && date_i18n(‘Ym’, strtotime($sticky_post1->post_date))!=$wp_query->query[‘m’]) {
// 去除不属于本月份的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
if($wp_query->is_day == 1 && date_i18n(‘Ymd’, strtotime($sticky_post1->post_date))!=$wp_query->query[‘m’]) {
// 去除不属于本日期的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
if($wp_query->is_author == 1 && $sticky_post1->post_author != $wp_query->query_vars[‘author’]) {
// 去除不属于本作者的文章
$offset1 = array_search($sticky_post1->ID, $sticky_posts);
unset( $sticky_posts[$offset1] );
}
}
$num_posts = count($posts);
$sticky_offset = 0;
// Loop over posts and relocate stickies to the front.
for ( $i = 0; $i < $num_posts; $i++ ) {
if ( in_array($posts[$i]->ID, $sticky_posts) ) {
$sticky_post = $posts[$i];
// Remove sticky from current position
array_splice($posts, $i, 1);
// Move to front, after other stickies
array_splice($posts, $sticky_offset, 0, array($sticky_post));
// Increment the sticky offset. The next sticky will be placed at this offset.
$sticky_offset++;
// Remove post from sticky posts array
$offset = array_search($sticky_post->ID, $sticky_posts);
unset( $sticky_posts[$offset] );
}
}
// If any posts have been excluded specifically, Ignore those that are sticky.
if ( !empty($sticky_posts) && !empty($wp_query->query_vars[‘post__not_in’] ) )
$sticky_posts = array_diff($sticky_posts, $wp_query->query_vars[‘post__not_in’]);
// Fetch sticky posts that weren’t in the query results
if ( !empty($sticky_posts) ) {
$stickies = get_posts( array(
‘post__in’ => $sticky_posts,
‘post_type’ => $wp_query->query_vars[‘post_type’],
‘post_status’ => ‘publish’,
‘nopaging’ => true
) );
foreach ( $stickies as $sticky_post ) {
array_splice( $posts, $sticky_offset, 0, array( $sticky_post ) );
$sticky_offset++;
}
}
}
return $posts;
}
1、如果你想让存档页也都显示全部置顶文章,那么就删掉11-43行的代码;
2、如果不想在某分类页显示置顶文章,将第 3 行的
1
|
if(
|
改成:
1
2 |
// abc是分类名称
if ( is_category( ‘abc’ ) || |
3、如果不想某标签页显示置顶文章,将第 3 行的
1
|
if(
|
改成:
1
2 |
// abc是标签名称
if ( is_tag( ‘abc’ ) || |
4、如果不想某作者页显示置顶文章,将第 3 行的
1
|
if(
|
改成:
1
2 |
// abc是作者昵称
if ( is_author( ‘abc’ ) || |
5、以上代码只对主循环有效,如果你在存档页使用WP_Query或query_posts来获取文章列表,又像让这些列表顶部显示置顶文章,可以把第3行代码中的以下代码删掉(注意:可能会导致文章显示数量跟你设置的不一样):
1
|
|| !is_main_query()
|
如果你想给置顶文章添加样式,将以下代码添加到functions.php中,会给置顶文章添加一个名为 sticky 的class。具体的css代码,再自行自定义:
1
2 3 4 5 6 7 8 |
add_filter(‘post_class’, ‘addStickyClass’ ,10,3 );
function addStickyClass( $classes, $class, $post_id ){ if( is_sticky() && is_category() && !isset( $classes[‘sticky’] ) ){ $classes[] = ‘sticky’; } return $classes; 转于 ;http://www.ludou.org/wordpress-sticky-posts-in-archive.html
|
日期:2024-03-24 浏览次数:43802 次
日期:2020-03-06 浏览次数:246678 次
日期:2018-07-07 浏览次数:318553 次
日期:2017-08-20 浏览次数:318916 次
日期:2016-09-09 浏览次数:319265 次
开发日期:2021-06-21 浏览次数:644025 次
开发日期:2021-04-21 浏览次数:702676 次
开发日期:2020-05-03 浏览次数:760168 次
开发日期:2019-12-02 浏览次数:739382 次
开发日期:2019-10-02 浏览次数:997343 次
日期:2013-07-19 浏览次数:15861 次
日期:2015-05-06 浏览次数:16503 次
日期:2012-06-16 浏览次数:42620 次
日期:2012-10-10 浏览次数:20321 次
日期:2012-12-15 浏览次数:23868 次
致力于互联网品牌建设与网络营销,专业领域包括网站建设、网站模板、移动互联网营销、wordpress平台开发等,服务范围涵盖基础的域名服务、主机 服务;企业邮箱、云服务器、网络营销等应用服务,为不同类型的客户提供良好的互联网应用定制解决方案,帮助客户在新的全球化互联网环境中保持优势。
爱永设计工作室一直致力于品牌精美的网页设计、网页制作DIV+CSS布局、JS效果、精美网站模板、标志设计、专业仿站, 低廉的价格,真诚的服务,我们拥有全国各地的客户群体和各行业的成功案例。以一流的服务,出色的网页设计和制作能力,认真严谨的工作态度为客户提供优质满意的服务。期待与您的合作!
Copyright © 2012 - 2024 aysheji.com All Rights Reserved 爱永设计 版权所有
邮箱:aysheji@163.com 在线客服:276583799 模板演示地址:www.aymoban.com 备案号:京ICP备13060102号-3
服务内容: 网页设计 网站建设 网站制作 网站模板 婚庆网站模板 摄影网站 手机网站制作 自适应网站制作