2013-09-27 34 views
0

我想添加onclick =「_ gaq.push(.....通過添加一個過濾器到主題的functions.php導航菜單,認爲這將是一個和平的蛋糕,但是沒有輸出,所以東西一定會出問題。WordPress的add_filter不做這項工作

這是WordPress的核心start_el功能

function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) { 
    $indent = ($depth) ? str_repeat("\t", $depth) : ''; 

    $class_names = $value = ''; 

    $classes = empty($item->classes) ? array() : (array) $item->classes; 
    $classes[] = 'menu-item-' . $item->ID; 

    $class_names = join(' ', apply_filters('nav_menu_css_class', array_filter($classes), $item, $args)); 
    $class_names = $class_names ? ' class="' . esc_attr($class_names) . '"' : ''; 

    $id = apply_filters('nav_menu_item_id', 'menu-item-'. $item->ID, $item, $args); 
    $id = $id ? ' id="' . esc_attr($id) . '"' : ''; 

    $output .= $indent . '<li' . $id . $value . $class_names .'>'; 

    $atts = array(); 
    $atts['title'] = ! empty($item->attr_title) ? $item->attr_title : ''; 
    $atts['target'] = ! empty($item->target)  ? $item->target  : ''; 
    $atts['rel'] = ! empty($item->xfn)  ? $item->xfn  : ''; 
    $atts['href'] = ! empty($item->url)  ? $item->url  : ''; 

    $atts = apply_filters('nav_menu_link_attributes', $atts, $item, $args); 

    $attributes = ''; 
    foreach ($atts as $attr => $value) { 
     if (! empty($value)) { 
      $value = ('href' === $attr) ? esc_url($value) : esc_attr($value); 
      $attributes .= ' ' . $attr . '="' . $value . '"'; 
     } 
    } 

    $item_output = $args->before; 
    $item_output .= '<a'. $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 start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) { 
    $indent = ($depth) ? str_repeat("\t", $depth) : ''; 

    $class_names = $value = ''; 

    $classes = empty($item->classes) ? array() : (array) $item->classes; 
    $classes[] = 'menu-item-' . $item->ID; 

    $class_names = join(' ', apply_filters('nav_menu_css_class', array_filter($classes), $item, $args)); 
    $class_names = $class_names ? ' class="' . esc_attr($class_names) . '"' : ''; 

    $id = apply_filters('nav_menu_item_id', 'menu-item-'. $item->ID, $item, $args); 
    $id = $id ? ' id="' . esc_attr($id) . '"' : ''; 

    $output .= $indent . '<li' . $id . $value . $class_names .'>'; 

    $atts = array(); 
    $atts['title'] = ! empty($item->attr_title) ? $item->attr_title : ''; 
    $atts['target'] = ! empty($item->target)  ? $item->target  : ''; 
    $atts['rel'] = ! empty($item->xfn)  ? $item->xfn  : ''; 
    $atts['href'] = ! empty($item->url)  ? $item->url  : ''; 

    $atts = apply_filters('nav_menu_link_attributes', $atts, $item, $args); 

    $attributes = ''; 
    foreach ($atts as $attr => $value) { 
     if (! empty($value)) { 
      $value = ('href' === $attr) ? esc_url($value) : esc_attr($value); 
      $attributes .= ' ' . $attr . '="' . $value . '"'; 
     } 
    } 

    $onclick = 'onclick="_gaq.push([\'_trackEvent\', \'Topmenu\', \'Click\',\''.$item->attr_title.'\'])"'; 

    $item_output = $args->before; 
    $item_output .= '<a'. $attributes .' '.$onclick.'>'; 
    $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); 
} 

只有兩個調整(在底部)代碼)

我加了這條線(從下10日線):

$onclick = 'onclick="_gaq.push([\'_trackEvent\', \'Topmenu\', \'Click\',\''.$item->attr_title.'\'])"'; 

而且我改變七號線從底部變成:

$item_output .= '<a'. $attributes .' '.$onclick.'>'; 

當我直接進行這些更改核心文件(wp-includes/nav-menu-template.php),它的工作原理。 我試過class Description_Walker extends Walker_Nav_Menu and add_filter但是這兩次我都沒有成功。

如何讓它正常工作?

回答

1

可以擴展Walker_Nav_Menu類是這樣的: 在你functions.php添加

class Description_Walker extends Walker_Nav_Menu{ 
    function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) { 
     your code here.... 
    } 
} 

然後將其添加到您的wp_nav_menu功能是這樣的:

wp_nav_menu(array( 
    your existing array emelents..., 
    'walker' => new Description_Walker 
)); 
+0

謝謝!我忘了將它添加到wp_nav_menu函數。 – WendiT