wordpress 使用步行者_Nav_Menu时无法向菜单项添加可选类

fykwrbwg  于 2023-08-03  发布在  WordPress
关注(0)|答案(3)|浏览(131)

作为一个WordPress初学者我正在创建菜单,也想定制<li>标签,以便能够通过CSS分配不同的类名来控制特定的行为,因此我使用custom walker来获得一个带有干净标记的列表,我在这里找到:
https://gist.github.com/toscho/1053467

class T5_Nav_Menu_Walker_Simple extends Walker_Nav_Menu
{
/**
* Start the element output.
*
* @param string $output Passed by reference. Used to append additional content.
* @param object $item Menu item data object.
* @param int $depth Depth of menu item. May be used for padding.
* @param array $args Additional strings.
* @return void
*/
public function start_el( &$output, $item, $depth, $args )
{
$output .= '<li>';
$attributes = '';
! empty ( $item->attr_title )
// Avoid redundant titles
and $item->attr_title !== $item->title
and $attributes .= ' title="' . esc_attr( $item->attr_title ) .'"';
! empty ( $item->url )
and $attributes .= ' href="' . esc_attr( $item->url ) .'"';
$attributes = trim( $attributes );
$title = apply_filters( 'the_title', $item->title, $item->ID );
$item_output = "$args->before<a $attributes>$args->link_before$title</a>"
. "$args->link_after$args->after";
// Since $output is called by reference we don't need to return anything.
$output .= apply_filters(
'walker_nav_menu_start_el'
, $item_output
, $item
, $depth
, $args
);
}
/**
* @see Walker::start_lvl()
*
* @param string $output Passed by reference. Used to append additional content.
* @return void
*/
public function start_lvl( &$output )
{
$output .= '<ul class="sub-menu">';
}
/**
* @see Walker::end_lvl()
*
* @param string $output Passed by reference. Used to append additional content.
* @return void
*/
public function end_lvl( &$output )
{
$output .= '</ul>';
}
/**
* @see Walker::end_el()
*
* @param string $output Passed by reference. Used to append additional content.
* @return void
*/
function end_el( &$output )
{
$output .= '</li>';
}
}

字符串
代码工作得很好。但是现在,当我想通过“Css classes”为菜单中的一个项目添加可选类时,它不起作用。

6jygbczu

6jygbczu1#

如果你只是想给一个或多个菜单项添加一个类,你可能会遇到困难。
使用“nav_menu_css_class”过滤器,而不是使用自定义步行者。类似于:

function my_special_nav_class( $classes, $item ) {
    // Decide if you want to add a class and add it to array $classes
    return $classes;
}
add_filter( 'nav_menu_css_class', 'my_special_nav_class', 10, 2 );

字符串

9njqaruj

9njqaruj2#

只要把类名放在li里面

public function start_el( &$output, $item, $depth, $args ){
    $output .= '<li class="YourCustomClassHere">';
    $attributes = '';
    ! empty ( $item->attr_title )
    // Avoid redundant titles
    and $item->attr_title !== $item->title
    and $attributes .= ' title="' . esc_attr( $item->attr_title ) .'"';
    ! empty ( $item->url )
    and $attributes .= ' href="' . esc_attr( $item->url ) .'"';
    $attributes = trim( $attributes );
    $title = apply_filters( 'the_title', $item->title, $item->ID );
    $item_output = "$args->before<a $attributes>$args->link_before$title</a>"
    . "$args->link_after$args->after";

    // Since $output is called by reference we don't need to return anything.
    $output .= apply_filters('walker_nav_menu_start_el', $item_output, $item, $depth, $args);
}

字符串

rryofs0p

rryofs0p3#

在外观->菜单->您的菜单->菜单项中添加自定义类到CSS类(可选)
屏幕选项检查CSS类
在类Yor_custom_class中扩展步行者_Nav_Menu

public function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0)
    {
        $custom_class  = in_array('my_custom_class', $item->classes) ? 'my_custom_class': '';

$output .= "<li class=\"menu__item $custom_class\`enter code here`">";

字符串

相关问题