2

wp_link_pages()用来显示分页,它看起来像:

1
<a href="/2">2</a>
<a href="/3">3</a>
<a href="/4">4</a>

由于这只是返回一个像上面这样格式化的 html 字符串,我发现很难将当前页码包装在一个跨度中,看起来像:

<span class="current">1</span>
<a href="/2">2</a>
<a href="/3">3</a>
<a href="/4">4</a>

如何在跨度标签中包装一个用空格(有时没有甚至<a>标签)包围的数字?

4

2 回答 2

2

将此代码放在functions.php中

function custom_wp_link_pages( $args = '' ) {
    $defaults = array(
        'before' => '<p id="post-pagination">' . __( 'Pages:' ), 
        'after' => '</p>',`enter code here`
        'text_before' => '',
        'text_after' => '',
        'next_or_number' => 'number', 
        'nextpagelink' => __( 'Next page' ),
        'previouspagelink' => __( 'Previous page' ),
        'pagelink' => '%',
        'echo' => 1
    );

    $r = wp_parse_args( $args, $defaults );
    $r = apply_filters( 'wp_link_pages_args', $r );
    extract( $r, EXTR_SKIP );

    global $page, $numpages, $multipage, $more, $pagenow;

    $output = '';
    if ( $multipage ) {
        if ( 'number' == $next_or_number ) {
            $output .= $before;
            for ( $i = 1; $i < ( $numpages + 1 ); $i = $i + 1 ) {
                $j = str_replace( '%', $i, $pagelink );
                $output .= ' ';
                if ( $i != $page || ( ( ! $more ) && ( $page == 1 ) ) )
                    $output .= _wp_link_page( $i );
                else
                    $output .= '<span class="current-post-page">';

                $output .= $text_before . $j . $text_after;
                if ( $i != $page || ( ( ! $more ) && ( $page == 1 ) ) )
                    $output .= '</a>';
                else
                    $output .= '</span>';
            }
            $output .= $after;
        } else {
            if ( $more ) {
                $output .= $before;
                $i = $page - 1;
                if ( $i && $more ) {
                    $output .= _wp_link_page( $i );
                    $output .= $text_before . $previouspagelink . $text_after . '</a>';
                }
                $i = $page + 1;
                if ( $i <= $numpages && $more ) {
                    $output .= _wp_link_page( $i );
                    $output .= $text_before . $nextpagelink . $text_after . '</a>';
                }
                $output .= $after;
            }
        }
    }

    if ( $echo )
        echo $output;

    return $output;
}

并打电话给custom_wp_link_pages()

资料来源:http ://bavotasan.com/2012/a-better-wp_link_pages-for-wordpress/

于 2012-07-30T22:31:07.647 回答
0

为什么正则表达式作为标签?

你需要使用类似的东西:

段落标签中的页面链接

<?php wp_link_pages('before=<p>&after=</p>&next_or_number=number&pagelink=page %'); ?>

显示包裹在段落标签中的页面链接。

DIV 中的页面链接

<?php wp_link_pages('before=<div id="page-links">&after=</div>'); ?>

在 DIV 中显示页面链接以供 CSS 参考为<div id="page-links">.

文档参考:http ://codex.wordpress.org/Function_Reference/wp_link_pages

于 2012-05-19T21:54:26.463 回答