wordpress url中的链接ID

时间:2015-04-30 08:49:06

标签: php wordpress permalinks slug

目前我正在使用wordpress网站,但我偶然发现了一个问题。

我正在使用wp_page_menu制作导航栏以访问其他页面。现在它引导我www.mysite.com/sport,但我需要它来引导我www.mysite.com/sport#headerwww.mysite.com/sport/#header

有谁知道我该怎么做?

我尝试使用不同的插件,或更换slug或永久链接,但这并没有给我我想要的结果。

感谢您的帮助!

2 个答案:

答案 0 :(得分:3)

确定。这是你的代码。我只是覆盖wordpress的默认walker。请关注此代码中的文本#header。

如果您担心此代码。所以你可以在1238行找到文件:... wp-includes / post-template.php。它的代码相同但我在get_permalink()之后添加了#header。

希望有所帮助。

 class WPSE_HasHeader_Custom_Walker extends Walker_Page {


        function start_el( &$output, $page, $depth = 0, $args = array(), $current_page = 0 ) {

            if ( $depth )
                $indent = str_repeat("\t", $depth);
            else
                $indent = '';

            extract($args, EXTR_SKIP);
            $css_class = array('page_item', 'page-item-'.$page->ID);

            if( isset( $args['pages_with_children'][ $page->ID ] ) )
                $css_class[] = 'page_item_has_children';

            if ( !empty($current_page) ) {
                $_current_page = get_post( $current_page );
                if ( in_array( $page->ID, $_current_page->ancestors ) )
                    $css_class[] = 'current_page_ancestor';
                if ( $page->ID == $current_page )
                    $css_class[] = 'current_page_item';
                elseif ( $_current_page && $page->ID == $_current_page->post_parent )
                    $css_class[] = 'current_page_parent';
            } elseif ( $page->ID == get_option('page_for_posts') ) {
                $css_class[] = 'current_page_parent';
            }

            $css_class = implode( ' ', apply_filters( 'page_css_class', $css_class, $page, $depth, $args, $current_page ) );

            if ( '' === $page->post_title )
                $page->post_title = sprintf( __( '#%d (no title)' ), $page->ID );

            /** CHANGE LINK HERE **/
            $output .= $indent . '<li class="' . $css_class . '"><a href="' . get_permalink($page->ID) . '#header">' . $link_before . apply_filters( 'the_title', $page->post_title, $page->ID ) . $link_after . '</a>';

            if ( !empty($show_date) ) {
                if ( 'modified' == $show_date )
                    $time = $page->post_modified;
                else
                    $time = $page->post_date;

                $output .= " " . mysql2date($date_format, $time);
            }
        }
    }

    wp_list_pages(array(
        'sort_column' => 'menu_order',
        'title_li'    => '',
        'echo'        => 1,
        'walker' => new WPSE_HasHeader_Custom_Walker()
    ));

更新:

第二种方式: 谢谢你的发展。我认为这与他有同样的想法,但在你的情况下更简单。像这样:

$link = wp_list_pages(array(
                        'sort_column' => 'menu_order',
                        'title_li'    => '',
                        'echo'        => 0,
                    ));
echo preg_replace('/<a(.*)href="([^"]*)"(.*)>/', '<a$1href="$2#header"$3>', $link);

答案 1 :(得分:2)

克里斯蒂安的答案很棒,它让我想到了替代方法,特别是那些允许你按照原始要求使用wp_page_menu()功能的方法。所以这是使用过滤器的另一种方法。

wp_page_menu()来电之前或在functions.php

中添加此功能
function wp_list_pages_addhash($output) {
    $dom = new DOMDocument;
    $dom->loadHTML($output);
    $links = $dom->getElementsByTagName('a');
    foreach ($links as $link) {
      $link->setAttribute('href', $link->getAttribute('href') . '#header');
    }
    $output = $dom->saveHTML();
    return $output;
}
add_filter('wp_list_pages', 'wp_list_pages_addhash');

然后使用您最初在主题中的wp_page_menu调用:

wp_page_menu();

说明:它会在wp_list_pages的输出中找到每个链接的每个href属性,并添加&#39;#header&#39;到最后。 wp_page_menu反过来使用wp_list_pages来创建输出。