Odpowiedzi:
Moje podejście Bez dodatkowej funkcji, bez filtra. :)
<?php $GLOBALS['wpdb']->current_post = 0; ?>
<div <?php post_class( 0 === ++$GLOBALS['wpdb']->current_post % 3 ? 'third' : '' ); ?>>
Alternatywny:
<div <?php post_class( 0 === ++$GLOBALS['wpdb']->wpse_post_counter % 3 ? 'third' : '' ); ?>>
Notice: Undefined property: wpdb::$current_post in
Jako dodatek do @helgathevikings odpowiedz
static
zmiennych wewnątrz klasy pozwala na takie samo zachowanie jak posiadanie zmiennych globalnych: pozostają one na swoim miejscu i nie zmieniają się, chyba że ich nie zmienisz.function wpse44845_add_special_post_class( $classes )
{
// Thanks to @Milo and @TomAuger for the heads-up in the comments
0 === $GLOBALS['wpdb']->current_post %3 AND $classes[] = 'YOUR CLASS';
return $classes;
}
add_filter( 'post_class','wpse44845_add_special_post_class' );
Możemy wykorzystać current_post
właściwość $wp_query
obiektu globalnego . Użyjmy anonimowej funkcji ze use
słowem kluczowym, aby przekazać globalną $wp_query
przez referencję ( PHP 5.3+ ):
add_filter( 'post_class', function( $classes ) use ( &$wp_query )
{
0 === $wp_query->current_post %3 AND $classes[] = 'YOUR CLASS';
return $classes;
} );
Następnie możemy ograniczyć go do głównej pętli za pomocą in_the_loop()
kontroli warunkowej.
$wpdb->current_post
?
jeśli Twój motyw używa post_class () do generowania klas postów, możesz spróbować. Nie jestem w 100% pewien, jak poradzi sobie z paginacją b / ci Nie mam wystarczającej liczby postów w mojej lokalnej instalacji, aby to przetestować
add_filter('post_class','wpa_44845');
global $current_count;
$current_count = 1;
function wpa_44845( $classes ){
global $current_count;
if ($current_count %3 == 0 ) $classes[] = 'special-class';
$current_count++;
return $classes;
}
static
var zamiast a, global
aby utrzymać przestrzeń nazw w czystości. W każdym razie: +1.
$wpdb->current_post
bez konieczności tworzenia innej zmiennej.
Istnieją również sposoby, aby to zrobić za pomocą CSS i javascript.
Z CSS3 kierujesz reklamy na co trzeci post za pomocą selektora n-tego dziecka.
article.post:nth-child(3n+0)
{
background-color: #777;
}
Lub za pomocą jQuery można dodać klasę CSS przy użyciu tej samej techniki.
jQuery(function($) {
$( "article.post:nth-child(3n+0)" ).addClass("custom-class");
});