Добавьте базу категорий к URL в пользовательском типе поста / таксономии


23

Я строю систему типов LMS в WordPress, контролируемую Custom Post types.
Тип сообщения называется Lessons(с фрагментом courses), и у него есть один custom taxonomy(категория) courses.

Структура URL домена отображается прямо сейчас как:

domain.com/courses/lesson-name,

Я хочу, чтобы это стало:

domain.com/courses/[course-name{category}]/lesson-name

или по существу:

/[cpt]/%category%/%postname%/

вот плагин, который я написал, который контролирует CPTsсейчас.

function rflms_post_type() {
    $labels = array(
        'name'                => _x( 'Lessons', 'Post Type General Name', 'text_domain' ),
        'singular_name'       => _x( 'Lesson', 'Post Type Singular Name', 'text_domain' ),
        'menu_name'           => __( 'Lessons', 'text_domain' ),
        'parent_item_colon'   => __( 'Parent Product:', 'text_domain' ),
        'all_items'           => __( 'All Lessons', 'text_domain' ),
        'view_item'           => __( 'View Lesson', 'text_domain' ),
        'add_new_item'        => __( 'Add New Lesson', 'text_domain' ),
        'add_new'             => __( 'New Lesson', 'text_domain' ),
        'edit_item'           => __( 'Edit Lesson', 'text_domain' ),
        'update_item'         => __( 'Update Lesson', 'text_domain' ),
        'search_items'        => __( 'Search Lessions', 'text_domain' ),
        'not_found'           => __( 'No Lessons Found', 'text_domain' ),
        'not_found_in_trash'  => __( 'No Lessons Found in Trash', 'text_domain' ),
    );

    $args = array(
        'label'               => __( 'Lessons', 'text_domain' ),
        'description'         => __( 'Referable Lessons', 'text_domain' ),
        'labels'              => $labels,
        'hierarchical'        => false,
        'public'              => true,
        'show_ui'             => true,
        'show_in_menu'        => true,
        'show_in_nav_menus'   => true,
        'show_in_admin_bar'   => true,
        'supports'        => array('premise-member-access', 'title', 'editor', 'author', 'thumbnail', 'excerpt', 'comments'),
        'menu_position'       => 5,
        'menu_icon'           => null,
        'can_export'          => true,
        'has_archive'         => true,
        'exclude_from_search' => false,
        'publicly_queryable'  => true,
        'capability_type'     => 'post',
        'rewrite'                    => array('slug' => 'courses'),
    );

    register_post_type( 'lessons', $args );


// Hook into the 'init' action

}
add_action( 'init', 'rflms_post_type', 0 );

// Register Custom Taxonomy
function custom_taxonomy()  {
    $labels = array(
        'name'                       => _x( 'Courses', 'Taxonomy General Name', 'text_domain' ),
        'singular_name'              => _x( 'Course', 'Taxonomy Singular Name', 'text_domain' ),
        'menu_name'                  => __( 'Courses', 'text_domain' ),
        'all_items'                  => __( 'All Courses', 'text_domain' ),
        'parent_item'                => __( 'Parent Course', 'text_domain' ),
        'parent_item_colon'          => __( 'Parent Course:', 'text_domain' ),
        'new_item_name'              => __( 'New Course Name', 'text_domain' ),
        'add_new_item'               => __( 'Add New Course', 'text_domain' ),
        'edit_item'                  => __( 'Edit Course', 'text_domain' ),
        'update_item'                => __( 'Update Course', 'text_domain' ),
        'separate_items_with_commas' => __( 'Separate Courses with commas', 'text_domain' ),
        'search_items'               => __( 'Search Courses', 'text_domain' ),
        'add_or_remove_items'        => __( 'Add or Remove Courses', 'text_domain' ),
        'choose_from_most_used'      => __( 'Choose from Most Used courses', 'text_domain' ),
    );

    $args = array(
        'labels'                     => $labels,
        'hierarchical'               => true,
        'public'                     => true,
        'show_ui'                    => true,
        'show_admin_column'          => true,
        'show_in_nav_menus'          => true,
        'show_tagcloud'              => false,
        'rewrite'                    => array('slug' => 'courses'),
    );

    register_taxonomy( 'course', 'lessons', $args );
}

// Hook into the 'init' action
add_action( 'init', 'custom_taxonomy', 0 );

В последнее время я сталкиваюсь с этой проблемой. Решено! [# 188834] [1] [1]: wordpress.stackexchange.com/questions/94817/…
maheshwaghmare

РЕШЕНИЕ! (После бесконечных исследований) <br/> <br/> Вам следует изменить post_type_linkфильтр. больше на: wordpress.stackexchange.com/a/167992/33667 )
Т.Тодуа

Ответы:


36

Измените переписывание, чтобы добавить запрос курса var:

'rewrite' => array('slug' => 'courses/%course%')

Затем фильтр, post_type_linkчтобы вставить выбранный курс в постоянную ссылку:

function wpa_course_post_link( $post_link, $id = 0 ){
    $post = get_post($id);  
    if ( is_object( $post ) ){
        $terms = wp_get_object_terms( $post->ID, 'course' );
        if( $terms ){
            return str_replace( '%course%' , $terms[0]->slug , $post_link );
        }
    }
    return $post_link;  
}
add_filter( 'post_type_link', 'wpa_course_post_link', 1, 3 );

Есть также плагины, такие как пользовательские постоянные ссылки типа поста, которые могут сделать это для вас.


Спасибо, я ценю ваш быстрый ответ. Это имеет полный смысл. Мне любопытно, где я могу вставить фильтр post_type_link? я могу просто пойти внизу всего документа?
Зак Рассел

Я добавил это к основанию, и это 404-ая страница.
Зак Рассел

1
Вы должны сбросить изменения, посетите страницу настроек постоянных ссылок.
Мило

также обратите внимание, что вы, вероятно, столкнетесь с таксономией и типом поста, которые будут использовать один и тот же фрагмент
Майло

На данный момент я делаю правильные постоянные ссылки, но не выполняю их правильно (это мягкий 404ing). Любые рекомендации о том, что я могу сделать, чтобы это работало правильно? Я удален от постоянной переписки. Просто нажмите «сохранить», и он обновит файл (это nginx, поэтому он контролируется в файле nginx.conf)
Зак Рассел

1

Ага! После долгих исследований я получил плагин « Пользовательские постоянные ссылки » . Который отвечает моим требованиям - пользовательский URL, например

  • для категории
  • для почты
  • для пользовательских сообщений
  • для пользовательской таксономии и т. д.

Как этот пользовательский тип сообщения - сообщение :

введите описание изображения здесь


1

Получил решение!

Чтобы иметь иерархические постоянные ссылки для пользовательского типа записи, установите плагин « Пользовательские типы сообщений» ( https://wordpress.org/plugins/custom-post-type-permalinks/ ).

Обновить зарегистрированный тип сообщения. У меня есть имя типа сообщения в качестве справочного центра

function help_centre_post_type(){
    register_post_type('helpcentre', array( 
        'labels'            =>  array(
            'name'          =>      __('Help Center'),
            'singular_name' =>      __('Help Center'),
            'all_items'     =>      __('View Posts'),
            'add_new'       =>      __('New Post'),
            'add_new_item'  =>      __('New Help Center'),
            'edit_item'     =>      __('Edit Help Center'),
            'view_item'     =>      __('View Help Center'),
            'search_items'  =>      __('Search Help Center'),
            'no_found'      =>      __('No Help Center Post Found'),
            'not_found_in_trash' => __('No Help Center Post in Trash')
                                ),
        'public'            =>  true,
        'publicly_queryable'=>  true,
        'show_ui'           =>  true, 
        'query_var'         =>  true,
        'show_in_nav_menus' =>  false,
        'capability_type'   =>  'page',
        'hierarchical'      =>  true,
        'rewrite'=> [
            'slug' => 'help-center',
            "with_front" => false
        ],
        "cptp_permalink_structure" => "/%help_centre_category%/%post_id%-%postname%/",
        'menu_position'     =>  21,
        'supports'          =>  array('title','editor', 'thumbnail'),
        'has_archive'       =>  true
    ));
    flush_rewrite_rules();
}
add_action('init', 'help_centre_post_type');

А вот и зарегистрированная таксономия

function themes_taxonomy() {  
    register_taxonomy(  
        'help_centre_category',  
        'helpcentre',        
        array(
            'label' => __( 'Categories' ),
            'rewrite'=> [
                'slug' => 'help-center',
                "with_front" => false
            ],
            "cptp_permalink_structure" => "/%help_centre_category%/",
            'hierarchical'               => true,
            'public'                     => true,
            'show_ui'                    => true,
            'show_admin_column'          => true,
            'show_in_nav_menus'          => true,
            'query_var' => true
        ) 
    );  
}  
add_action( 'init', 'themes_taxonomy');

Эта строка делает вашу постоянную работу

"cptp_permalink_structure" => "/%help_centre_category%/%post_id%-%postname%/",

вы можете удалить %post_id%и можете сохранить/%help_centre_category%/%postname%/"

Не забудьте удалить постоянные ссылки с приборной панели.


1

Решение для меня состояло из трех частей. В моем случае тип сообщения называется trainings.

  1. Добавьте 'rewrite' => array('slug' => 'trainings/%cat%')к register_post_typeфункции.
  2. Измените слаг, чтобы иметь динамическую категорию.
  3. «Прослушайте» новый динамический URL и загрузите соответствующий шаблон.

Итак, вот как динамически изменить постоянную ссылку для данного типа записи. Добавить к functions.php:

function vx_soon_training_post_link( $post_link, $id = 0 ) {
    $post = get_post( $id );
    if ( is_object( $post ) ) {
        $terms = wp_get_object_terms( $post->ID, 'training_cat' );
        if ( $terms ) {
            return str_replace( '%cat%', $terms[0]->slug, $post_link );
        }
    }

    return $post_link;
}

add_filter( 'post_type_link', 'vx_soon_training_post_link', 1, 3 );

... и вот как загрузить соответствующий шаблон на новый динамический URL. Добавить к functions.php:

function archive_rewrite_rules() {
    add_rewrite_rule(
        '^training/(.*)/(.*)/?$',
        'index.php?post_type=trainings&name=$matches[2]',
        'top'
    );
    //flush_rewrite_rules(); // use only once
}

add_action( 'init', 'archive_rewrite_rules' );

Это оно! Не забудьте обновить постоянные ссылки, сохранив постоянные ссылки снова в de backend. Или используйте flush_rewrite_rules()функцию.


1

Вам необходимо обновить строку ниже, где вы зарегистрировали пользовательский тип записи, используя функцию register_post_type.

'rewrite' => array ('slug' => 'courses /% cat%')

Чтобы динамически изменить постоянную ссылку типа поста, вы должны добавить следующий код в файл functions.php:

function change_link( $post_link, $id = 0 ) {
    $post = get_post( $id );
    if( $post->post_type == 'courses' ) 
    {
       if ( is_object( $post ) ) {
          $terms = wp_get_object_terms( $post->ID, array('course') );
          if ( $terms ) {
             return str_replace( '%cat%', $terms[0]->slug, $post_link );
         }
      }
    }
    return   $post_link ;
}
add_filter( 'post_type_link', 'change_link', 1, 3 );

//load the template on the new generated URL otherwise you will get 404's the page

function generated_rewrite_rules() {
   add_rewrite_rule(
       '^courses/(.*)/(.*)/?$',
       'index.php?post_type=courses&name=$matches[2]',
       'top'
   );
}
add_action( 'init', 'generated_rewrite_rules' );

После этого вам нужно сбросить перезаписываемые постоянные ссылки, зайдите в wp-admin> Настройки> Постоянные ссылки . просто обновите настройку постоянной ссылки с помощью кнопки «Сохранить изменения».

он вернет URL, как показано ниже:

  • domain.com/courses/[course-name{category}]/lesson-name

Спасибо!


0

Это работает для меня:

'rewrite' => array(
        'slug' => 'portfolio',
        'with_front' => false,
        'hierarchical' => true // to display category/subcategroy
    ),

5
Это не использует категории или их путь, это только делает пользовательский тип поста иерархическим.
Йорис Кроос

0

Всем, кто интересуется решением, без необходимости возиться с необработанным PHP-кодом, я настоятельно рекомендую плагин Permalink Manager Lite от Maciej Bis. Это спасатель жизни.

Он имеет визуальный механизм для удаления или добавления любой части, которую вы хотите в URL пользовательского типа поста, основанной на «permastructs»:

Снимок экрана: Постоянная ссылка Manager Lite

(Несмотря на все трудности, связанные с простым структурированием URL с помощью пользовательских типов записей, мы собирались отказаться от WP и перейти на другую CMS. Но этот плагин в сочетании с ACF и CPTUI или Pods делает Wordpress довольно профессиональным.)

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.