Jawaban:
Pendekatan saya Tidak ada fungsi tambahan, tidak ada filter. :)
<?php $GLOBALS['wpdb']->current_post = 0; ?>
<div <?php post_class( 0 === ++$GLOBALS['wpdb']->current_post % 3 ? 'third' : '' ); ?>>
Alternatif:
<div <?php post_class( 0 === ++$GLOBALS['wpdb']->wpse_post_counter % 3 ? 'third' : '' ); ?>>
Notice: Undefined property: wpdb::$current_post in
Sebagai tambahan jawaban @helgathevikings
static
variabel di dalam kelas memungkinkan perilaku yang sama dengan memiliki variabel global: Mereka tetap di tempatnya dan tidak berubah, kecuali jika Anda tidak mengubahnya.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' );
Kita dapat memanfaatkan current_post
properti dari $wp_query
objek global . Mari kita gunakan fungsi anonim , dengan use
kata kunci, untuk meneruskan global $wp_query
dengan referensi ( PHP 5.3+ ):
add_filter( 'post_class', function( $classes ) use ( &$wp_query )
{
0 === $wp_query->current_post %3 AND $classes[] = 'YOUR CLASS';
return $classes;
} );
Selanjutnya, kita bisa membatasi ke loop utama dengan pemeriksaan in_the_loop()
bersyarat.
$wpdb->current_post
?
jika tema Anda menggunakan post_class () untuk menghasilkan kelas posting, Anda bisa mencoba. Saya tidak 100% yakin bagaimana ini akan menangani pagination b / ci tidak memiliki cukup posting pada instalasi lokal saya untuk mengujinya
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 bukannya global
untuk menjaga namespace tetap bersih. Pokoknya: +1.
$wpdb->current_post
tanpa harus membuat variabel lain.
Ada juga cara untuk melakukan ini dengan CSS dan javascript.
Dengan CSS3, Anda menargetkan setiap pos ketiga dengan pemilih anak-n.
article.post:nth-child(3n+0)
{
background-color: #777;
}
Atau dengan jQuery, Anda bisa menambahkan kelas CSS menggunakan teknik yang sama.
jQuery(function($) {
$( "article.post:nth-child(3n+0)" ).addClass("custom-class");
});