Je travaille sur un projet personnalisé pour un client et j'ai un problème avec l'ajout de data-scroll
avant les liens dans WordPress. Je veux que la sortie soit <a data-scroll href='#'>
.
Le défilement de données est ce que je cherche à ajouter juste après le a, ici href ="#"
J'espère que quelqu'un pourra m'aider.
Un Walker personnalisé serait le meilleur moyen d’ajouter quoi que ce soit à votre wp_nav_menu
Vous devez garder ce qui suit dans votre function.php
<?php
class MV_Cleaner_Walker_Nav_Menu extends Walker {
var $tree_type = array( 'post_type', 'taxonomy', 'custom' );
var $db_fields = array( 'parent' => 'menu_item_parent', 'id' => 'db_id' );
function start_lvl(&$output, $depth) {
$indent = str_repeat("\t", $depth);
$output .= "\n$indent<ul class=\"sub-menu\">\n";
}
function end_lvl(&$output, $depth) {
$indent = str_repeat("\t", $depth);
$output .= "$indent</ul>\n";
}
function start_el(&$output, $item, $depth, $args) {
global $wp_query;
$indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';
$class_names = $value = '';
$classes = empty( $item->classes ) ? array() : (array) $item->classes;
$classes = in_array( 'current-menu-item', $classes ) ? array( 'current-menu-item' ) : array();
$class_names = join( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item, $args ) );
$class_names = strlen( trim( $class_names ) ) > 0 ? ' class="' . esc_attr( $class_names ) . '"' : '';
$id = apply_filters( 'nav_menu_item_id', '', $item, $args );
$id = strlen( $id ) ? ' id="' . esc_attr( $id ) . '"' : '';
$output .= $indent . '<li' . $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 ) .'"' : '';
$attributes .= ! empty( $item->url ) ? ' href="' . esc_attr( $item->url ) .'"' : '';
$item_output = $args->before;
$item_output .= '<a data-scroll'. $attributes .'>';
$item_output .= $args->link_before . apply_filters( 'the_title', $item->title, $item->ID ) . $args->link_after;
$item_output .= '</a>';
$item_output .= $args->after;
$output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
}
function end_el(&$output, $item, $depth) {
$output .= "</li>\n";
}
}
?>
et alors vous pouvez appeler le menu par
<?php wp_nav_menu( array( 'menu'=>'Footer Menu 1',
menu_class => 'menu vertical footer-menu',
'walker' => new MV_Cleaner_Walker_Nav_Menu() ) ); ?>
Vous voudrez utiliser le filtre suivant:
Exemple:
function filter_nav_menu_link_attributes($atts, $item, $args) {
if ( isset($args->theme_location) && $args->theme_location === 'my-menu-location' ) {
$atts['data-scroll'] = 'some-value';
}
return $atts;
}
add_filter('nav_menu_link_attributes', 'filter_nav_menu_link_attributes', 10, 3);
Utilisez $item
et $args
pour isoler et agir sur le menu spécifique ou sur un élément de menu spécifique dans lequel vous souhaitez ajouter votre attribut.
Lisez plus ici: nav_menu_link_attributes
Vous devez ajouter ce code au fichier functions.php du thème actuel.
add_action( 'wp_footer', 'add_attr_nav_menu_link' );
function add_attr_nav_menu_link(){
?>
<script type="text/javascript">
jQuery( document ).ready(function() {
jQuery('.nav-menu ul.menu li a').each(function() {
jQuery(".nav-menu ul.menu li a").attr('data-scroll', '');
});
});
</script>
<?php
}
Faites-moi savoir si vous avez une requête !!!!