WordPress分類與標(biāo)簽等存檔頁實(shí)現(xiàn)置頂?shù)姆椒?/h1>
發(fā)布時(shí)間:2014-12-25 10:32:00 作者:佚名
我要評論
這篇文章主要為大家介紹了WordPress分類與標(biāo)簽等存檔頁實(shí)現(xiàn)置頂?shù)姆椒?通過二次開發(fā)實(shí)現(xiàn)存檔頁的置頂功能,是非常實(shí)用的技巧,需要的朋友可以參考下
本文實(shí)例講述了WordPress分類與標(biāo)簽等存檔頁實(shí)現(xiàn)置頂?shù)姆椒?。分享給大家供大家參考。具體分析如下:
在wordpress中默認(rèn)能置頂文章就是只有首頁了,如果我們希望分類/標(biāo)簽等存檔頁也能置頂文章我們需要二次開發(fā).
現(xiàn)在參考wp-includes/query.php中首頁置頂?shù)拇a,稍微修改一下,可以讓分類頁、標(biāo)簽頁、作者頁和日期頁等存檔頁面也能像首頁一樣在頂部顯示其范圍內(nèi)的置頂文章,把下面的代碼放到當(dāng)前主題下的functions.php中就可以了.
復(fù)制代碼代碼如下: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) && !emptyempty($sticky_posts) && !get_query_var('ignore_sticky_posts') ) { $stickies1 = get_posts( array( 'post__in' => $sticky_posts ) );
foreach ( $stickies1 as $sticky_post1 ) {
// 判斷當(dāng)前是否分類頁
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)) {
// 去除不屬于本標(biāo)簽的文章
$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 ( !emptyempty($sticky_posts) && !emptyempty($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 ( !emptyempty($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 行的
復(fù)制代碼代碼如下:if(
//改成:
// abc是分類名稱
if ( is_category( 'abc' ) ||
3、如果不想某標(biāo)簽頁顯示置頂文章,將第 3 行的代碼
復(fù)制代碼代碼如下:if(
//改成:
// abc是標(biāo)簽名稱
if ( is_tag( 'abc' ) ||
4、如果不想某作者頁顯示置頂文章,將第 3 行的
復(fù)制代碼代碼如下:if(
//改成:
// abc是作者昵稱
if ( is_author( 'abc' ) ||
5、以上代碼只對主循環(huán)有效,如果你在存檔頁使用WP_Query或query_posts來獲取文章列表,又像讓這些列表頂部顯示置頂文章,可以把第3行代碼中的以下代碼刪掉(注意:可能會(huì)導(dǎo)致文章顯示數(shù)量跟你設(shè)置的不一樣):
代碼如下:
復(fù)制代碼代碼如下:|| !is_main_query()
置頂樣式:如果你想給置頂文章添加樣式,將以下代碼添加到functions.php中,會(huì)給置頂文章添加一個(gè)名為 sticky 的class,具體的css代碼,再自行自定義:
復(fù)制代碼代碼如下: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;
}
希望本文所述對大家的WordPress建站有所幫助。
相關(guān)文章
wordpress如何設(shè)置文章置頂以及區(qū)分置頂文章與普通文章
很多博客都有自己的置頂文章,除了位置差異外,跟其他文章是沒有任何區(qū)別的,那我們怎樣才能將它們區(qū)別開來呢,本文將介紹幾種方法,需要的朋友可以參考下 2012-12-16 如何給wordpress創(chuàng)建動(dòng)態(tài)的置頂文章長時(shí)間引起注意
置頂文章的作用是希望長時(shí)間引起讀者注意,可以表明站點(diǎn)的簡介、版權(quán)聲明、友情鏈接的交換原則等;本文將介紹如何給wordpress創(chuàng)建動(dòng)態(tài)的置頂文章,需要了解的朋友可以參考下 2012-12-19 -
在WordPress中,或許你希望調(diào)用設(shè)置好的指定文章列表,這一功能如何實(shí)現(xiàn)呢?下文就介紹實(shí)現(xiàn)方法,大家參考使用吧
2014-02-26
如何在wordpress上增加文件上傳的大小限制(多種實(shí)現(xiàn)方法)
碰到這么一個(gè)問題,需要在一篇文章中加入一個(gè)大小為19.4MB的PDF文件,而wordpress限定的文件大小只有8MB,那么如何在WP博客上上傳文件,而且文件大小不受限制呢?本文只限A 2012-12-28 WordPress中非插件實(shí)現(xiàn)嵌套回復(fù)效果的方法
Wordpress博客從2.7版本就自帶了嵌套回復(fù)功能,但是很多主題都沒有添加該效果,大部分博主也用博客插件來實(shí)現(xiàn)該功能,可博客插件的嵌套回復(fù)的內(nèi)容樣式與父評論不能保持一致 2010-09-11 WordPress 評論者超鏈接實(shí)現(xiàn)重定向跳轉(zhuǎn)的方法
今天我們要實(shí)現(xiàn)的就是即使收到再多的垃圾評論,這些發(fā)送評論的站點(diǎn)也不會(huì)被搜索引擎索引到。 2011-01-30 WordPress 有人回復(fù)時(shí)郵件通知的實(shí)現(xiàn)方法 SAE 移植版
常見的 Wordress 郵件通知功能,使用起來非常的簡單 2012-06-07 Wordpress實(shí)現(xiàn)單篇文章分頁顯示的方法
這篇文章主要為大家介紹了Wordpress實(shí)現(xiàn)單篇文章分頁顯示的方法,分析了文章頁面的分頁原理與對應(yīng)js文件的修改方法,是非常實(shí)用的技巧,需要的朋友可以參考下 2014-12-18 WordPress中添加語音搜索功能的實(shí)現(xiàn)方法
這篇文章主要為大家介紹了WordPress中添加語音搜索功能的實(shí)現(xiàn)方法,屬于html5 的speech功能的API,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下 2014-12-18 Wordpress實(shí)現(xiàn)自帶的側(cè)邊欄和自定義的側(cè)邊欄同時(shí)存在的方法
這篇文章主要為大家介紹了Wordpress實(shí)現(xiàn)自帶的側(cè)邊欄和自定義的側(cè)邊欄同時(shí)存在的方法,是WordPress二次開發(fā)中非常實(shí)用的技巧,需要的朋友可以參考下 2014-12-22
最新評論

本文實(shí)例講述了WordPress分類與標(biāo)簽等存檔頁實(shí)現(xiàn)置頂?shù)姆椒?。分享給大家供大家參考。具體分析如下:
在wordpress中默認(rèn)能置頂文章就是只有首頁了,如果我們希望分類/標(biāo)簽等存檔頁也能置頂文章我們需要二次開發(fā).
現(xiàn)在參考wp-includes/query.php中首頁置頂?shù)拇a,稍微修改一下,可以讓分類頁、標(biāo)簽頁、作者頁和日期頁等存檔頁面也能像首頁一樣在頂部顯示其范圍內(nèi)的置頂文章,把下面的代碼放到當(dāng)前主題下的functions.php中就可以了.
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) && !emptyempty($sticky_posts) && !get_query_var('ignore_sticky_posts') ) { $stickies1 = get_posts( array( 'post__in' => $sticky_posts ) );
foreach ( $stickies1 as $sticky_post1 ) {
// 判斷當(dāng)前是否分類頁
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)) {
// 去除不屬于本標(biāo)簽的文章
$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 ( !emptyempty($sticky_posts) && !emptyempty($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 ( !emptyempty($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 行的
//改成:
// abc是分類名稱
if ( is_category( 'abc' ) ||
3、如果不想某標(biāo)簽頁顯示置頂文章,將第 3 行的代碼
//改成:
// abc是標(biāo)簽名稱
if ( is_tag( 'abc' ) ||
4、如果不想某作者頁顯示置頂文章,將第 3 行的
//改成:
// abc是作者昵稱
if ( is_author( 'abc' ) ||
5、以上代碼只對主循環(huán)有效,如果你在存檔頁使用WP_Query或query_posts來獲取文章列表,又像讓這些列表頂部顯示置頂文章,可以把第3行代碼中的以下代碼刪掉(注意:可能會(huì)導(dǎo)致文章顯示數(shù)量跟你設(shè)置的不一樣):
代碼如下:
置頂樣式:如果你想給置頂文章添加樣式,將以下代碼添加到functions.php中,會(huì)給置頂文章添加一個(gè)名為 sticky 的class,具體的css代碼,再自行自定義:
function addStickyClass( $classes, $class, $post_id ){
if( is_sticky() && is_category() && !isset( $classes['sticky'] ) ){
$classes[] = 'sticky';
}
return $classes;
}
希望本文所述對大家的WordPress建站有所幫助。
相關(guān)文章
wordpress如何設(shè)置文章置頂以及區(qū)分置頂文章與普通文章
很多博客都有自己的置頂文章,除了位置差異外,跟其他文章是沒有任何區(qū)別的,那我們怎樣才能將它們區(qū)別開來呢,本文將介紹幾種方法,需要的朋友可以參考下2012-12-16如何給wordpress創(chuàng)建動(dòng)態(tài)的置頂文章長時(shí)間引起注意
置頂文章的作用是希望長時(shí)間引起讀者注意,可以表明站點(diǎn)的簡介、版權(quán)聲明、友情鏈接的交換原則等;本文將介紹如何給wordpress創(chuàng)建動(dòng)態(tài)的置頂文章,需要了解的朋友可以參考下2012-12-19- 在WordPress中,或許你希望調(diào)用設(shè)置好的指定文章列表,這一功能如何實(shí)現(xiàn)呢?下文就介紹實(shí)現(xiàn)方法,大家參考使用吧2014-02-26
如何在wordpress上增加文件上傳的大小限制(多種實(shí)現(xiàn)方法)
碰到這么一個(gè)問題,需要在一篇文章中加入一個(gè)大小為19.4MB的PDF文件,而wordpress限定的文件大小只有8MB,那么如何在WP博客上上傳文件,而且文件大小不受限制呢?本文只限A2012-12-28WordPress中非插件實(shí)現(xiàn)嵌套回復(fù)效果的方法
Wordpress博客從2.7版本就自帶了嵌套回復(fù)功能,但是很多主題都沒有添加該效果,大部分博主也用博客插件來實(shí)現(xiàn)該功能,可博客插件的嵌套回復(fù)的內(nèi)容樣式與父評論不能保持一致2010-09-11WordPress 評論者超鏈接實(shí)現(xiàn)重定向跳轉(zhuǎn)的方法
今天我們要實(shí)現(xiàn)的就是即使收到再多的垃圾評論,這些發(fā)送評論的站點(diǎn)也不會(huì)被搜索引擎索引到。2011-01-30WordPress 有人回復(fù)時(shí)郵件通知的實(shí)現(xiàn)方法 SAE 移植版
常見的 Wordress 郵件通知功能,使用起來非常的簡單2012-06-07Wordpress實(shí)現(xiàn)單篇文章分頁顯示的方法
這篇文章主要為大家介紹了Wordpress實(shí)現(xiàn)單篇文章分頁顯示的方法,分析了文章頁面的分頁原理與對應(yīng)js文件的修改方法,是非常實(shí)用的技巧,需要的朋友可以參考下2014-12-18WordPress中添加語音搜索功能的實(shí)現(xiàn)方法
這篇文章主要為大家介紹了WordPress中添加語音搜索功能的實(shí)現(xiàn)方法,屬于html5 的speech功能的API,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-18Wordpress實(shí)現(xiàn)自帶的側(cè)邊欄和自定義的側(cè)邊欄同時(shí)存在的方法
這篇文章主要為大家介紹了Wordpress實(shí)現(xiàn)自帶的側(cè)邊欄和自定義的側(cè)邊欄同時(shí)存在的方法,是WordPress二次開發(fā)中非常實(shí)用的技巧,需要的朋友可以參考下2014-12-22