Übersetzen Sie benutzerdefinierte Links im Menü mit mqtranslate plus auf WordPress

Lesezeit: 21 Minuten

Benutzeravatar von Tasos
Tasos

Nach dieser Frage Wie kann ich die LINKS meines Navigationsmenüs mit qtranslate auf WordPress übersetzen? Ich versuche, mein Navigationsmenü auch in andere Sprachen zu übersetzen.

Ich habe alles getan, was in der ersten Antwort geschrieben steht:

  1. Schließen Sie die Funktion ein function.php
  2. Ergänzen Sie die 'walker' => new CustomLinkModifierWalker() auf der header.php Datei.
  3. Ändern Sie den Namen des Navigationsmenüs in <!- -:en- ->HOME<!- -:- -><!- -:gr- ->ΑΡΧΙΚΗ<!- -:- -> und URL zu /en|en"https://stackoverflow.com/"gr|

Allerdings funktioniert die Übersetzung nicht. Das Menü zeigt beide Strings in der Navigation an HOMEΑΡΧΙΚΗ und der Link ist /en|en"https://stackoverflow.com/"gr|.

Was mache ich falsch? Oder gibt es eine andere Möglichkeit, das Menü zu übersetzen?

Unter WordPress 4.0.1

AKTUALISIEREN

Ändern der Namen in [:en]HOME[:el]ΑΡΧΙΚΗ Ohne den obigen Code funktionieren die Übersetzungen, aber ich kann die URLs immer noch nicht zum Laufen bringen.

AKTUALISIERUNG 2

Menübild

Und der Navmenu-Code:

Für Griechisch:

<ul class="menu" id="nav-menu">
<li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-1091"><a href="https://stackoverflow.com/">ΑΡΧΙΚΗ</a></li>
<li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-1092"><a href="/#our-company">ΣΧΕΤΙΚΑ</a></li>
</ul> 

Für Englisch:

<ul class="menu" id="nav-menu">
<li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-1091"><a href="https://stackoverflow.com/">HOME</a></li>
<li class="menu-item menu-item-type-custom menu-item-object-custom current-menu-item current_page_item menu-item-1092"><a href="/#our-company">ABOUT</a></li>
</ul>

AKTUALISIERUNG 3

Ich habe versucht, die URL mit dem vollständigen Pfad einschließlich der Tags wie folgt hinzuzufügen:

[:en]http://www.mydomain.gr/en[:el]http://www.mydomain.gr

Aber nachdem ich auf “Speichern” geklickt habe, ist die URL-Eingabe leer. Der URL-Pfad wird nicht gespeichert.
UPDATE 4

Ich füge den Code in der functions.php und die Zeile in der header.php hinzu. Jetzt habe ich eine optionale URL auf der Admin-Seite. Also habe ich die URL entfernt und optional wie folgt hinzugefügt:

<!--:en-->/en<!--:--><!--:el-->/<!--:-->

Dann habe ich den Code in die header.php eingefügt:

 <?php $defaults = array(
      'theme_location'  => 'other',
      'container'       => '',
      'echo'            => true,
      'fallback_cb'     => 'wp_page_menu',
      'before'          => '',
      'after'           => '',
      'link_before'     => '',
      'link_after'      => '',
    'items_wrap'      => '<ul id="nav-menu" class="%2$s">%3$s</ul>',
    'depth'           => 0,
    'walker'          => ''
    );
    wp_nav_menu( $defaults );
    wp_nav_menu( array( 'theme_location' => 'primary', 'menu_class' => 'nav-menu' , 'walker' => new qTranslate_Menu_Walker() ) );
    ?>
  </div>

Das Problem ist, dass die Links in diesem Format: /en/#about funktioniert aber Links in diesem Format /en/blog funktioniert nicht und leitet zur Standardsprache weiter.

  • Teilen Sie den Screenshot und Ihren Menücode.

    – Murtaza Khursheed Hussain

    3. Februar 2015 um 8:25 Uhr


  • Ich habe die Frage mit dem Bild aktualisiert. Welchen Teil des Menücodes möchten Sie? Es ist eine riesige Datei, um es hier hinzuzufügen.

    – Tasos

    3. Februar 2015 um 8:37 Uhr

  • weißt du wie man code inspiziert? Wenn ja, teilen Sie den Screenshot von nav html im Code-Inspektor.

    – Murtaza Khursheed Hussain

    3. Februar 2015 um 9:19 Uhr

  • @MurtazaHussain Hoffe du meinst das Update

    – Tasos

    3. Februar 2015 um 11:42 Uhr

  • ohhh scheint dein Problem in der Base urlgehen Sie in die Einstellungen und prüfen Sie, ob URL Gibt es.

    – Murtaza Khursheed Hussain

    3. Februar 2015 um 11:49 Uhr

Benutzeravatar von Rosmarine Popcorn
Rosmarines Popcorn

Ich habe versucht herauszufinden, ob beim Speichern des URL-Felds im Menü ein Filter für den Prozess aufgerufen wird, und es scheint, als würde WordPress dies selbst tun, ohne die Möglichkeit zu lassen, den Filter aufzuheben.

In Anbetracht dessen habe ich eine Lösung gefunden, indem ich ein zusätzliches Feld namens Optionale URL verwendet habe, und wenn dieses Feld mit etwas gefüllt ist (nicht gefilterter Inhalt), wird WordPress dies anstelle des URL-Felds verwenden, wie es normalerweise der Fall ist.

Platzieren Sie also bitte diesen Code ganz unten in Ihrer functions.php, oder Sie können ihn in ein anderes Skript einfügen und in functions einfügen:

    //Return the custom meta
    function um_add_optional_url( $menu_item ) {
        $menu_item->optional_url = get_post_meta( $menu_item->ID, '_menu_item_optional_url', true );
        return $menu_item;
    }
    add_filter( 'wp_setup_nav_menu_item', 'um_add_optional_url' );

    //Update and save the optional url
    function um_update_optional_url( $menu_id, $menu_item_db_id, $args ) {
        if ( is_array( $_REQUEST['menu-item-optional-url']) ) {
            $subtitle_value = $_REQUEST['menu-item-optional-url'][$menu_item_db_id];
            update_post_meta( $menu_item_db_id, '_menu_item_optional_url', $subtitle_value );
        }
    }
    add_action( 'wp_update_nav_menu_item', 'um_update_optional_url', 10, 3 );
    //Custom Menu Walker to get the stored values
    class qTranslate_Menu_Walker extends Walker {
        /**
         * What the class handles.
         *
         * @see Walker::$tree_type
         * @since 3.0.0
         * @var string
         */
        public $tree_type = array( 'post_type', 'taxonomy', 'custom' );

        /**
         * Database fields to use.
         *
         * @see Walker::$db_fields
         * @since 3.0.0
         * @todo Decouple this.
         * @var array
         */
        public $db_fields = array( 'parent' => 'menu_item_parent', 'id' => 'db_id' );

        /**
         * Starts the list before the elements are added.
         *
         * @see Walker::start_lvl()
         *
         * @since 3.0.0
         *
         * @param string $output Passed by reference. Used to append additional content.
         * @param int    $depth  Depth of menu item. Used for padding.
         * @param array  $args   An array of arguments. @see wp_nav_menu()
         */
        public function start_lvl( &$output, $depth = 0, $args = array() ) {
            $indent = str_repeat("\t", $depth);
            $output .= "\n$indent<ul class=\"sub-menu\">\n";
        }

        /**
         * Ends the list of after the elements are added.
         *
         * @see Walker::end_lvl()
         *
         * @since 3.0.0
         *
         * @param string $output Passed by reference. Used to append additional content.
         * @param int    $depth  Depth of menu item. Used for padding.
         * @param array  $args   An array of arguments. @see wp_nav_menu()
         */
        public function end_lvl( &$output, $depth = 0, $args = array() ) {
            $indent = str_repeat("\t", $depth);
            $output .= "$indent</ul>\n";
        }

        /**
         * Start the element output.
         *
         * @see Walker::start_el()
         *
         * @since 3.0.0
         *
         * @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. Used for padding.
         * @param array  $args   An array of arguments. @see wp_nav_menu()
         * @param int    $id     Current item ID.
         */
        public function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {
            $indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';

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

            /**
             * Filter the CSS class(es) applied to a menu item's list item element.
             *
             * @since 3.0.0
             * @since 4.1.0 The `$depth` parameter was added.
             *
             * @param array  $classes The CSS classes that are applied to the menu item's `<li>` element.
             * @param object $item    The current menu item.
             * @param array  $args    An array of {@see wp_nav_menu()} arguments.
             * @param int    $depth   Depth of menu item. Used for padding.
             */
            $class_names = join( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item, $args, $depth ) );
            $class_names = $class_names ? ' class="' . esc_attr( $class_names ) . '"' : '';

            /**
             * Filter the ID applied to a menu item's list item element.
             *
             * @since 3.0.1
             * @since 4.1.0 The `$depth` parameter was added.
             *
             * @param string $menu_id The ID that is applied to the menu item's `<li>` element.
             * @param object $item    The current menu item.
             * @param array  $args    An array of {@see wp_nav_menu()} arguments.
             * @param int    $depth   Depth of menu item. Used for padding.
             */
            $id = apply_filters( 'nav_menu_item_id', 'menu-item-'. $item->ID, $item, $args, $depth );
            $id = $id ? ' id="' . esc_attr( $id ) . '"' : '';

            $output .= $indent . '<li' . $id . $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        : '';

            /**
             * Filter the HTML attributes applied to a menu item's anchor element.
             *
             * @since 3.6.0
             * @since 4.1.0 The `$depth` parameter was added.
             *
             * @param array $atts {
             *     The HTML attributes applied to the menu item's `<a>` element, empty strings are ignored.
             *
             *     @type string $title  Title attribute.
             *     @type string $target Target attribute.
             *     @type string $rel    The rel attribute.
             *     @type string $href   The href attribute.
             * }
             * @param object $item  The current menu item.
             * @param array  $args  An array of {@see wp_nav_menu()} arguments.
             * @param int    $depth Depth of menu item. Used for padding.
             */
            $atts = apply_filters( 'nav_menu_link_attributes', $atts, $item, $args, $depth );

            $attributes="";
            foreach ( $atts as $attr => $value ) {
                if ( ! empty( $value ) ) {
                    $value = ( 'href' === $attr ) ? esc_url( $value ) : esc_attr( $value );
                    //Inject the optional URL in case it exists and the attribute is href
                    if('href' === $attr){
                        if(property_exists($item,'optional_url') && $item->optional_url){
                            $value = __($item->optional_url);
                        }
                    }
                    $attributes .= ' ' . $attr . '="' . $value . '"';
                }
            }

            $item_output = $args->before;
            $item_output .= '<a'. $attributes .'>';
            //$item_output .= property_exists($item,'optional_url') ? $item->optional_url : "no";
            /** This filter is documented in wp-includes/post-template.php */
            $item_output .= $args->link_before . apply_filters( 'the_title', $item->title, $item->ID ) . $args->link_after;
            $item_output .= '</a>';
            $item_output .= $args->after;

            /**
             * Filter a menu item's starting output.
             *
             * The menu item's starting output only includes `$args->before`, the opening `<a>`,
             * the menu item's title, the closing `</a>`, and `$args->after`. Currently, there is
             * no filter for modifying the opening and closing `<li>` for a menu item.
             *
             * @since 3.0.0
             *
             * @param string $item_output The menu item's starting HTML output.
             * @param object $item        Menu item data object.
             * @param int    $depth       Depth of menu item. Used for padding.
             * @param array  $args        An array of {@see wp_nav_menu()} arguments.
             */
            $output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
        }

        /**
         * Ends the element output, if needed.
         *
         * @see Walker::end_el()
         *
         * @since 3.0.0
         *
         * @param string $output Passed by reference. Used to append additional content.
         * @param object $item   Page data object. Not used.
         * @param int    $depth  Depth of page. Not Used.
         * @param array  $args   An array of arguments. @see wp_nav_menu()
         */
        public function end_el( &$output, $item, $depth = 0, $args = array() ) {
            $output .= "</li>\n";
        }

    } // Walker_Nav_Menu


//Custom Walker on edit screen  
add_filter( 'wp_edit_nav_menu_walker', 'custom_nav_edit_walker',10,2 );
function custom_nav_edit_walker($walker,$menu_id) {
    return 'Walker_Nav_Menu_Edit_Custom';
}

class Walker_Nav_Menu_Edit_Custom extends Walker_Nav_Menu  {
    /**
     * @see Walker_Nav_Menu::start_lvl()
     * @since 3.0.0
     *
     * @param string $output Passed by reference.
     */
    function start_lvl( &$output, $depth = 0, $args = array() ) {
        $indent = str_repeat("\t", $depth);
        $output .= "\n$indent<ul class=\"sub-menu\">\n";
    }

    /**
     * @see Walker_Nav_Menu::end_lvl()
     * @since 3.0.0
     *
     * @param string $output Passed by reference.
     */
    function end_lvl( &$output, $depth = 0, $args = array() ) {
        $indent = str_repeat("\t", $depth);
        $output .= "$indent</ul>\n";
    }
    /**
     * @see Walker::start_el()
     * @since 3.0.0
     *
     * @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. Used for padding.
     * @param object $args
     */
    function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {
        global $_wp_nav_menu_max_depth;
        $_wp_nav_menu_max_depth = $depth > $_wp_nav_menu_max_depth ? $depth : $_wp_nav_menu_max_depth;

        $indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';

        ob_start();
        $item_id = esc_attr( $item->ID );
        $removed_args = array(
            'action',
            'customlink-tab',
            'edit-menu-item',
            'menu-item',
            'page-tab',
            '_wpnonce',
        );

        $original_title="";
        if ( 'taxonomy' == $item->type ) {
            $original_title = get_term_field( 'name', $item->object_id, $item->object, 'raw' );
            if ( is_wp_error( $original_title ) )
                $original_title = false;
        } elseif ( 'post_type' == $item->type ) {
            $original_object = get_post( $item->object_id );
            $original_title = $original_object->post_title;
        }

        $classes = array(
            'menu-item menu-item-depth-' . $depth,
            'menu-item-' . esc_attr( $item->object ),
            'menu-item-edit-' . ( ( isset( $_GET['edit-menu-item'] ) && $item_id == $_GET['edit-menu-item'] ) ? 'active' : 'inactive'),
        );

        $title = $item->title;

        if ( ! empty( $item->_invalid ) ) {
            $classes[] = 'menu-item-invalid';
            /* translators: %s: title of menu item which is invalid */
            $title = sprintf( __( '%s (Invalid)' ), $item->title );
        } elseif ( isset( $item->post_status ) && 'draft' == $item->post_status ) {
            $classes[] = 'pending';
            /* translators: %s: title of menu item in draft status */
            $title = sprintf( __('%s (Pending)'), $item->title );
        }

        $title = empty( $item->label ) ? $title : $item->label;

        ?>
    <li id="menu-item-<?php echo $item_id; ?>" class="<?php echo implode(' ', $classes ); ?>">
        <dl class="menu-item-bar">
            <dt class="menu-item-handle">
                <span class="item-title"><?php echo esc_html( $title ); ?></span>
                <span class="item-controls">
                    <span class="item-type"><?php echo esc_html( $item->type_label ); ?></span>
                    <span class="item-order hide-if-js">
                        <a href="https://stackoverflow.com/questions/28175174/<?php
                        echo wp_nonce_url(
                            add_query_arg(
                                array("action' => 'move-up-menu-item',
                                    'menu-item' => $item_id,
                                ),
                                remove_query_arg($removed_args, admin_url( 'nav-menus.php' ) )
                            ),
                            'move-menu_item'
                        );
                        ?>" class="item-move-up"><abbr title="<?php esc_attr_e('Move up'); ?>">&#8593;</abbr></a>
                        |
                        <a href="https://stackoverflow.com/questions/28175174/<?php
                        echo wp_nonce_url(
                            add_query_arg(
                                array("action' => 'move-down-menu-item',
                                    'menu-item' => $item_id,
                                ),
                                remove_query_arg($removed_args, admin_url( 'nav-menus.php' ) )
                            ),
                            'move-menu_item'
                        );
                        ?>" class="item-move-down"><abbr title="<?php esc_attr_e('Move down'); ?>">&#8595;</abbr></a>
                    </span>
                    <a class="item-edit" id="edit-<?php echo $item_id; ?>" title="<?php esc_attr_e('Edit Menu Item'); ?>" href="<?php
                    echo ( isset( $_GET['edit-menu-item'] ) && $item_id == $_GET['edit-menu-item'] ) ? admin_url( 'nav-menus.php' ) : add_query_arg( 'edit-menu-item', $item_id, remove_query_arg( $removed_args, admin_url( 'nav-menus.php#menu-item-settings-' . $item_id ) ) );
                    ?>"><?php _e( 'Edit Menu Item' ); ?></a>
                </span>
            </dt>
        </dl>

        <div class="menu-item-settings" id="menu-item-settings-<?php echo $item_id; ?>">
            <?php if( 'custom' == $item->type ) : ?>
                <p class="field-url description description-wide">
                    <label for="edit-menu-item-url-<?php echo $item_id; ?>">
                        <?php _e( 'URL' ); ?><br />
                        <input type="text" id="edit-menu-item-url-<?php echo $item_id; ?>" class="widefat code edit-menu-item-url" name="menu-item-url[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->url ); ?>" />
                    </label>
                </p>
            <?php endif; ?>
            <p class="description description-thin">
                <label for="edit-menu-item-title-<?php echo $item_id; ?>">
                    <?php _e( 'Navigation Label' ); ?><br />
                    <input type="text" id="edit-menu-item-title-<?php echo $item_id; ?>" class="widefat edit-menu-item-title" name="menu-item-title[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->title ); ?>" />
                </label>
            </p>
            <p class="description description-thin">
                <label for="edit-menu-item-attr-title-<?php echo $item_id; ?>">
                    <?php _e( 'Title Attribute' ); ?><br />
                    <input type="text" id="edit-menu-item-attr-title-<?php echo $item_id; ?>" class="widefat edit-menu-item-attr-title" name="menu-item-attr-title[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->post_excerpt ); ?>" />
                </label>
            </p>
            <p class="field-link-target description">
                <label for="edit-menu-item-target-<?php echo $item_id; ?>">
                    <input type="checkbox" id="edit-menu-item-target-<?php echo $item_id; ?>" value="_blank" name="menu-item-target[<?php echo $item_id; ?>]"<?php checked( $item->target, '_blank' ); ?> />
                    <?php _e( 'Open link in a new window/tab' ); ?>
                </label>
            </p>
            <p class="field-css-classes description description-thin">
                <label for="edit-menu-item-classes-<?php echo $item_id; ?>">
                    <?php _e( 'CSS Classes (optional)' ); ?><br />
                    <input type="text" id="edit-menu-item-classes-<?php echo $item_id; ?>" class="widefat code edit-menu-item-classes" name="menu-item-classes[<?php echo $item_id; ?>]" value="<?php echo esc_attr( implode(' ', $item->classes ) ); ?>" />
                </label>
            </p>
            <p class="field-xfn description description-thin">
                <label for="edit-menu-item-xfn-<?php echo $item_id; ?>">
                    <?php _e( 'Link Relationship (XFN)' ); ?><br />
                    <input type="text" id="edit-menu-item-xfn-<?php echo $item_id; ?>" class="widefat code edit-menu-item-xfn" name="menu-item-xfn[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->xfn ); ?>" />
                </label>
            </p>
            <p class="field-description description description-wide">
                <label for="edit-menu-item-description-<?php echo $item_id; ?>">
                    <?php _e( 'Description' ); ?><br />
                    <textarea id="edit-menu-item-description-<?php echo $item_id; ?>" class="widefat edit-menu-item-description" rows="3" cols="20" name="menu-item-description[<?php echo $item_id; ?>]"><?php echo esc_html( $item->description ); // textarea_escaped ?></textarea>
                    <span class="description"><?php _e('The description will be displayed in the menu if the current theme supports it.'); ?></span>
                </label>
            </p>
            <?php
            /*
             * This is the added field
             */
            if($item->type == 'custom'):
            ?>
            <p class="field-custom description description-wide">
                <label for="edit-menu-item-custom-<?php echo $item_id; ?>">
                    <?php _e( 'Optional URL' ); ?><br />
                    <input type="text" id="edit-menu-item-custom-<?php echo $item_id; ?>" class="widefat code edit-menu-item-custom" name="menu-item-optional-url[<?php echo $item_id; ?>]" value="<?php echo $item->optional_url; ?>" />
                    <span class="description">Place an URL to use instead of the original one, while this one does not strip tags (stays unfiltered)</span>
                </label>
            </p>
            <?php
            endif;
            /*
             * end added field
             */
            ?>
            <div class="menu-item-actions description-wide submitbox">
                <?php if( 'custom' != $item->type && $original_title !== false ) : ?>
                    <p class="link-to-original">
                        <?php printf( __('Original: %s'), '<a href="' . esc_attr( $item->url ) . '">' . esc_html( $original_title ) . '</a>' ); ?>
                    </p>
                <?php endif; ?>
                <a class="item-delete submitdelete deletion" id="delete-<?php echo $item_id; ?>" href="<?php
                echo wp_nonce_url(
                    add_query_arg(
                        array(
                            'action' => 'delete-menu-item',
                            'menu-item' => $item_id,
                        ),
                        remove_query_arg($removed_args, admin_url( 'nav-menus.php' ) )
                    ),
                    'delete-menu_item_' . $item_id
                ); ?>"><?php _e('Remove'); ?></a> <span class="meta-sep"> | </span> <a class="item-cancel submitcancel" id="cancel-<?php echo $item_id; ?>" href="<?php echo esc_url( add_query_arg( array('edit-menu-item' => $item_id, 'cancel' => time()), remove_query_arg( $removed_args, admin_url( 'nav-menus.php' ) ) ) );
                ?>#menu-item-settings-<?php echo $item_id; ?>"><?php _e('Cancel'); ?></a>
            </div>

            <input class="menu-item-data-db-id" type="hidden" name="menu-item-db-id[<?php echo $item_id; ?>]" value="<?php echo $item_id; ?>" />
            <input class="menu-item-data-object-id" type="hidden" name="menu-item-object-id[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->object_id ); ?>" />
            <input class="menu-item-data-object" type="hidden" name="menu-item-object[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->object ); ?>" />
            <input class="menu-item-data-parent-id" type="hidden" name="menu-item-parent-id[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->menu_item_parent ); ?>" />
            <input class="menu-item-data-position" type="hidden" name="menu-item-position[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->menu_order ); ?>" />
            <input class="menu-item-data-type" type="hidden" name="menu-item-type[<?php echo $item_id; ?>]" value="<?php echo esc_attr( $item->type ); ?>" />
        </div><!-- .menu-item-settings-->
        <ul class="menu-item-transport"></ul>
        <?php
        $output .= ob_get_clean();
    }
}

Dann bearbeiten Sie Ihre header.php oder wo auch immer Sie anrufen wp_nav_menu function und übergeben Sie diesen neuen Walker als Parameter:

wp_nav_menu( array( 'theme_location' => 'primary', 'menu_class' => 'nav-menu' , 'walker' => new qTranslate_Menu_Walker() ) );

Wo qTranslate_Menu_Walker ist der neue Walker, der die URL durch eine optionale URL ersetzt hat

PS: Verwenden Sie die <!--:en-->These language tags instead<!--:-->

  • Ich werde es heute später überprüfen, da ich jetzt keinen Zugriff auf den FTP habe. Aber ich komme bald wieder 🙂

    – Tasos

    25. Februar 2015 um 8:20 Uhr

  • kannst du bitte das letzte Update überprüfen? Es scheint, dass wir auf einem guten Weg sind, aber die Probleme sollten irgendwo in der header.php liegen

    – Tasos

    25. Februar 2015 um 8:58 Uhr

  • @AnastasiosVentouris hast du den Walker auf wp_nav_menu platziert? Kannst du das Problem expliziter ansprechen?

    – Rosmarines Popcorn

    25. Februar 2015 um 10:42 Uhr

  • Wie meinst du das? Ich platziere den Code auf header.php unter den Standardwerten. Sie können es an der Frage zu Update 4 sehen….Das Problem ist, dass alle Links auf der Startseite (zB “www.mydomain.com”, “www.mydomain.com/#about”, “www.mydomain.com/#about”, “www.mydomain .com/#contact) funktioniert mit Ihrem Code problemlos, aber wenn ich einen Link zu einer anderen Seite habe, ist der Link so wie er sein sollte (zB “www.mydomain.com/en/blog”), aber wenn ich klicke es, es leitet es auf die Standardsprache um. “www.mydomain.com/blog. Nur die Links zu einer anderen Seite.

    – Tasos

    25. Februar 2015 um 11:50 Uhr

  • @AnastasiosVentouris kannst du die Rohdaten auf deinen Menüpunkten platzieren, ich werde das überprüfen, schick mir einfach deine URLs mit Sprach-Tags

    – Rosmarines Popcorn

    25. Februar 2015 um 13:23 Uhr

Benutzeravatar von Omer Farooq
Omer Farooq

qtranslate hat dieses Problem schon lange, Ihre Implementierung funktioniert, wenn Sie einen Link haben, aber wenn Sie verschiedene Links für verschiedene Sprachen haben, funktioniert dies nicht. Eine Lösung für dieses Problem ist sehr einfach, Sie müssen nur Menüs für verschiedene Sprachen hinzufügen und in der Kopfzeile können Sie diese Menüs abhängig von der aktuellen Sprache aufrufen, die der Benutzer ausgewählt hat.

<?php
if(qtrans_getLanguage()=='en') // put your code here if the current language code is 'en' (English)
{

wp_nav_menu( array('menu' => 'Nav_en' ));

} elseif(qtrans_getLanguage()=='es') // put your code here if the current language code is 'es' (Español)
{
wp_nav_menu( array('menu' => 'Nav' ));
}
?>

BEARBEITEN:

Eine andere Möglichkeit, dies mit einem einzigen Menü zum Laufen zu bringen, wäre das Hinzufügen dieses Codes zu Ihrer functions.php

// Makes menu urls work with Qtranslate
function qtranslate_menu_item( $menu_item ) {
  if (stripos($menu_item->url, get_site_url()) !== false){
    $menu_item->url = qtrans_convertURL($menu_item->url);
  }     
  return $menu_item;
}

add_filter('wp_setup_nav_menu_item', 'qtranslate_menu_item', 0);
/**************************************************/

Hallo Anastasios Ventouris,

Ich hatte ein neues Plugin in meinem WordPress-Setup überprüft, es gibt ein Plugin mit dem Namen "Transposh Translation Filter". Es funktioniert gut in meinem WordPress, alle Inhalte, die auf der WordPress-Site geladen sind, einschließlich Menü, benutzerdefiniertem Menülink und all diese Dinge funktionieren gut in meinem WordPress.

Sie mussten nur den Sprachnamen auf der Admin-Seite hinzufügen und dann zur Widget-Seite gehen und dieses Widget hinzufügen, wo Sie Ihr Übersetzungs-Plugin anzeigen möchten.

Wenn Sie sich jetzt für die afrikanische Sprache entscheiden, werden Ihre Site-Daten in diese Sprache konvertiert und das richtige Format und die richtige Ausgabe auf Ihrem Bildschirm angezeigt.

Probieren Sie dieses Plugin aus und teilen Sie mir Ihre Ansichten und Ideen mit.

mqTranslate wurde zugunsten von qTranslate X aufgegeben. Anstatt eine Lösung für ein veraltetes Plug-in zu finden, rate ich Ihnen dringend, qTranslate X zu verwenden. Es ist benutzerfreundlicher und hat zusätzliche Funktionen.

Benutzeravatar von Prabhash Rawat
Prabhash Rawat

Sie können diesen Update-Code ausprobieren.

<!--:en-->Ayahuasca<!--:--><!--:ru-->Аяуаска<!--:-->

Dies ist ein aktualisierter Code für die Menüübersetzung. Und noch eine Sache beim Übersetzen Ihrer Website: Verwenden Sie mqTranslate anstelle von qTranslate. Beide haben die gleiche Funktionalität, aber mqTranslate hat eine aktualisierte Version für WordPress …

ich hoffe, dies wird dir helfen

Screenshots für die Menüübersetzung

  • Wenn Sie die Frage lesen, werden Sie sehen, dass ich es bereits versucht habe. Das Problem liegt an der URL für eine benutzerdefinierte Seite und nicht an einer normalen Seite mit einem einfachen Titel

    – Tasos

    12. Februar 2015 um 14:15 Uhr

  • Wenn Sie die Frage lesen, werden Sie sehen, dass ich es bereits versucht habe. Das Problem liegt an der URL für eine benutzerdefinierte Seite und nicht an einer normalen Seite mit einem einfachen Titel

    – Tasos

    12. Februar 2015 um 14:15 Uhr

1393080cookie-checkÜbersetzen Sie benutzerdefinierte Links im Menü mit mqtranslate plus auf WordPress

This website is using cookies to improve the user-friendliness. You agree by using the website further.

Privacy policy