Je suis nouveau dans le développement wordpress, essayant juste de convertir mon code HTML en un thème WordPress, j'ai commencé avec le thème vierge de Chris Coyer.
<div class="navigation">
<div class="next-posts">
<?php next_posts_link('« Older Entries') ?>
</div>
<div class="prev-posts">
<?php previous_posts_link('Newer Entries »') ?>
</div>
</div>
Comment puis-je sortir le div seulement s'il y a une next_posts_link()
. J'ai besoin de cela car je vais utiliser <ul>
pour ma pagination. Si je ne fais pas ça, j'aurai une balle vide
Vous pouvez utiliser get_previous_posts_link
et get_next_posts_link
pour déterminer s’ils existent comme ceci:
$prev_link = get_previous_posts_link(__('« Older Entries'));
$next_link = get_next_posts_link(__('Newer Entries »'));
// as suggested in comments
if ($prev_link || $next_link) {
echo '<ul class="navigation">';
if ($prev_link){
echo '<li>'.$prev_link .'</li>';
}
if ($next_link){
echo '<li>'.$next_link .'</li>';
}
echo '</ul>';
}
J'espère que cela t'aides
Je l'ai écrit il y a quelque temps, mais devrait toujours être valide:
http://www.ericmmartin.com/conditional-pagepost-navigation-links-in-wordpress-redux/
Vous pouvez ajouter la fonction suivante à votre fichier functions.php
:
/**
* If more than one page exists, return TRUE.
*/
function show_posts_nav() {
global $wp_query;
return ($wp_query->max_num_pages > 1);
}
La mise à jour de votre code pour:
<?php if (show_posts_nav()) : ?>
<div class="navigation">
<div class="next-posts"><?php next_posts_link('« Older Entries') ?></div>
<div class="prev-posts"><?php previous_posts_link('Newer Entries »') ?></div>
</div>
<?php endif; ?>
la meilleure solution consiste à vérifier $wp_query->max_num_pages
, mais vous pouvez également utiliser:
<?php
if(paginate_links()) {
...
}