非插件实现WP博客具体页码分页导航
来源: 阅读:710 次 日期:2014-09-03 14:22:17
温馨提示: 小编为您整理了“非插件实现WP博客具体页码分页导航”,方便广大网友查阅!
,p>在很多WordPress主题中,分页导航都是采用传统的“上一页”“下一页”两个链接,但这种方法并不实用,我们希望把他变成“1 2 3 ...”具体的页码。有一个实现方法是使用WP-Pagenavi插件,但这么一个小小的功能,我们希望把它整合进主题中,以减少对插件的依赖。

具体的实现方法是:

1.首先在主题functions.php中加入以下代码:

/* Pagenavi */

function pagenavi( $before = '', $after = '', $p = 2 ) {

if ( is_singular() ) return;

global $wp_query, $paged;

$max_page = $wp_query->max_num_pages;

if ( $max_page == 1 ) return;

if ( empty( $paged ) ) $paged = 1;

echo $before.'<div id="pagenavi">'."n";

echo '<span class="pages">Page: ' . $paged . ' of ' . $max_page . ' </span>';

if ( $paged > 1 ) p_link( $paged - 1, 'Previous Page', '«' );

if ( $paged > $p + 1 ) p_link( 1, 'First Page' );

if ( $paged > $p + 2 ) echo '... ';

for( $i = $paged - $p; $i <= $paged + $p; $i++ ) {

if ( $i > 0 && $i <= $max_page ) $i == $paged ? print "<span class='page-numbers current'>{$i}</span>" : p_link( $i );

}

if ( $paged < $max_page - $p - 1 ) echo '... ';

if ( $paged < $max_page - $p ) p_link( $max_page, 'Last Page' );

if ( $paged < $max_page ) p_link( $paged + 1,'Next Page', '»' );

echo '</div>'.$after."n";

}

function p_link( $i, $title = '', $linktype = '' ) {

if ( $title == '' ) $title = "Page {$i}";

if ( $linktype == '' ) { $linktext = $i; } else { $linktext = $linktype; }

echo "<a class='page-numbers' href='", esc_html( get_pagenum_link( $i ) ), "' title='{$title}'>{$linktext}</a>";

}

2.然后在页面相应位置,把原来的分页导航代码改成以下:

<?php pagenavi(); ?>

这样就已经实现了分页导航,但此时的分页导航还很难看,页码都挤在一起,所以我们需要在style.css中进行适当装饰:

/* pagenavi */

#pagenavi a, #pagenavi a:visited, #pagenavi span {

height: 25px;

line-height: 25px;

display: inline-block;

padding: 1px 8px;

}

#pagenavi a, #pagenavi a:visited {

margin: 0 2px;

}

#pagenavi span.pages {

color: #777;

font-weight: bold;

margin-right: 10px;

padding: 0;

}

#pagenavi span.current {

margin: -2px 2px -1px;

padding: 0 9px;

height: 28px;

line-height: 28px;

text-align: center;

}

当然,这里只是简单的装饰,你可以根据主题风格做必要的修改。

更多信息请查看IT技术专栏

更多信息请查看CMS教程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2025国考·省考课程试听报名

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map