嗯,经过一些更深入的研究,我终于找到了一个可行的解决方案,它干净、简单,迄今为止工作完美无瑕。
把这个放进你的函数里。php创建自定义walker,将经典的permalinks转换为哈希(例如,page.com/mypage到page.com/#mypage):
/* Custom nav walker */
class Single_Page_Walker extends Walker_Nav_Menu{
function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) {
global $wp_query;
$indent = ( $depth ) ? str_repeat( "\\t", $depth ) : \'\';
$class_names = $value = \'\';
$classes = empty( $item->classes ) ? array() : (array) $item->classes;
$class_names = join( \' \', apply_filters( \'nav_menu_css_class\', array_filter( $classes ), $item ) );
$class_names = \' class="\'. esc_attr( $class_names ) . \'"\';
$output .= $indent . \'<li id="menu-item-\'. $item->ID . \'"\' . $value . $class_names .\'>\';
$attributes = ! empty( $item->attr_title ) ? \' title="\' . esc_attr( $item->attr_title ) .\'"\' : \'\';
$attributes .= ! empty( $item->target ) ? \' target="\' . esc_attr( $item->target ) .\'"\' : \'\';
$attributes .= ! empty( $item->xfn ) ? \' rel="\' . esc_attr( $item->xfn ) .\'"\' : \'\';
if($item->object == \'page\')
{
$varpost = get_post($item->object_id);
if(is_home()){
$attributes .= \' href="#\' . $varpost->post_name . \'"\';
}else{
$attributes .= \' href="\'.home_url().\'/#\' . $varpost->post_name . \'"\';
}
}
else
$attributes .= ! empty( $item->url ) ? \' href="\' . esc_attr( $item->url ) .\'"\' : \'\';
$item_output = $args->before;
$item_output .= \'<a\'. $attributes .\'>\';
$item_output .= $args->link_before . apply_filters( \'the_title\', $item->title, $item->ID );
$item_output .= $args->link_after;
$item_output .= \'</a>\';
$item_output .= $args->after;
$output .= apply_filters( \'walker_nav_menu_start_el\', $item_output, $item, $depth, $args, $id );
}
}
然后,在希望菜单出现的地方,放置以下代码来调用菜单(在functions.php中之前应该将其定义为菜单位置),并根据自己的喜好调整选项,除了“walker”部分之外:
<?php
wp_nav_menu(array(
\'theme_location\' => \'onepage\',
\'echo\' => true,
\'container\' => false,
\'walker\'=> new Single_Page_Walker,
\'depth\' => 1) );
?>
-已经这样了。现在,您可以在后端填充菜单,而无需再关心哈希:)。