WP REST API отримує повідомлення від типу публікації


15

Як я можу отримати всі повідомлення від певного користувальницького типу публікації за допомогою API WP REST (або v1, або v2)? Я дуже новачок у цьому і намагаюся зрозуміти, як це зробити.

На даний момент я використовую WP REST API v2 і мені вдалося отримати список усіх типів публікацій за допомогою цього

http://domain.com/wp-json/wp/v2/types

а потім вдалося отримати тип публікації, який мене цікавить

http://domain.com/wp-json/wp/v2/types/the-icons-update

Як мені отримати всі публікації від певного типу вмісту?

Я спробував

http://domain.com/wp-json/wp/v2/posts?filter[post_type]=the-icons-update

Але він повертає порожній масив (я вважаю, що він повертає повідомлення за замовчуванням, і на моєму веб-сайті є лише повідомлення в спеціальному типі публікацій, які я намагаюся отримати).

Чи може виникнути проблема із тим, як я зареєстрував тип публікації?

function custom_post_type() {
$labels = array(
    'name'               => _x( 'The Icons Update', 'post type general name' ),
    'singular_name'      => _x( 'The Icons Update', 'post type singular name' ),
    'add_new'            => _x( 'Add Page', 'magazine' ),
    'add_new_item'       => __( 'Add New Page' ),
    'edit_item'          => __( 'Edit Page' ),
    'new_item'           => __( 'New Page' ),
    'all_items'          => __( 'All Pages' ),
    'view_item'          => __( 'View Page' ),
    'search_items'       => __( 'Search Pages' ),
    'not_found'          => __( 'No Page found' ),
    'not_found_in_trash' => __( 'No Page found in the Trash' ), 
    'parent_item_colon'  => '',
    'menu_icon'          => '',
    'menu_name'          => 'The Icons Update'
);
$args = array(
    'labels'        => $labels,
    'description'   => 'Holds our projects and project specific data',
    'public'        => true,
    'menu_position' => 5,
    'supports'      => array( 'title', 'editor', 'thumbnail', 'excerpt', 'custom-fields' ),
    'has_archive'   => true,
    'taxonomies'    => array('post_tag', 'category'),
    'hierarchical'  => false,
    'query_var'     => true,
    'queryable' => true,
        'searchable'    => true,
    'rewrite'       => array( 'slug' => 'the-icons-update' )
);
register_post_type( 'magazine', $args );
flush_rewrite_rules();
}
add_action( 'init', 'custom_post_type' );

Будь-яка допомога з цим дійсно вдячна.

Відповіді:


18

Просто додайте наступний параметр до функції register_post_type, він може бути перед параметром 'menu_position'. 'show_in_rest' => вірно

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

якщо ви використовуєте плагін для реєстрації свого поштового типу, ви можете використовувати наступний код:

add_action( 'init', 'add_anuncios_to_json_api', 30 );
function add_anuncios_to_json_api(){
    global $wp_post_types;
    $wp_post_types['anuncio']->show_in_rest = true;
}

після цього ви зможете перелічити свої публікації з mydomain.com/wp-json/wp/v2/posttype_slug

у моєму випадку: mydomain.com/wp-json/wp/v2/anuncio

ви також можете зареєструвати нову базу, використовуючи наступний код:

add_action( 'init', 'add_anuncios_to_json_api', 30 );
function add_anuncios_to_json_api(){
    global $wp_post_types;
    $wp_post_types['anuncio']->show_in_rest = true;
    $wp_post_types['anuncio']->rest_base = 'clasi';
    $wp_post_types['anuncio']->rest_controller_class = 'WP_REST_Posts_Controller';
}

просто замініть anuncioна ваш пост пошти, і "clasi" стане вашим маршрутом. mydomain.com/wp-json/wp/v2/clasi


Дякую, це майже вирішило мою проблему! Тепер я отримую деякі повідомлення від цього конкретного типу публікації, але не всі вони з’являються, а також їх дані не є повними, наприклад, категорія не вказана, і мені також потрібні перелічені спеціальні поля (у WP REST API v1.2.3 Мені вдалося зробити так, щоб ACF з'явився). Дякуємо за допомогу з цього приводу
Jeff

4

Щоб відобразити спеціальні типи публікацій у версії 2, вам потрібно додати 'show_in_rest' => trueаргументи функції register_post_type, тоді ваші публікації з таким користувацьким типом публікації будуть доступні в кінцевій точці: wp-json / wp / v2 / your-custom-post-type .

Джерело: http://scottbolinger.com/custom-post-types-wp-api-v2/


0

Ви повинні використовувати це: -

http://domain.com/wp-json/wp/v2/posts?job-type=your-post-type 

Сподіваюся, що це працює :)


Дякую вам за вашу відповідь, але це не спрацювало :(
Jeff

Зверніть увагу, якщо ви встановили query_var значення false під час реєстрації спеціальної таксономії, вам потрібно буде змінити параметри на: wp-json / wp / v2 / posts /? Taxonomy = job-type & term = manager (це лише приклад)
dev

Дякую, але це також не вийшло. Чи може виникнути проблема із тим, як я зареєстрував спеціальний тип публікації? Я оновив питання, якщо ви можете поглянути на це, я був би дуже вдячний
Jeff

Та тільки що перевірив оновлений відповідь
DEV

0

Добре ось моя повна відповідь: -

function prefix_register_post_type()
{
  register_post_type(
    'prefix_portfolio',
    array(
      'labels'        => array(
        'name'               => __('Portfolio', 'text_domain'),
        'singular_name'      => __('Portfolio', 'text_domain'),
        'menu_name'          => __('Portfolio', 'text_domain'),
        'name_admin_bar'     => __('Portfolio Item', 'text_domain'),
        'all_items'          => __('All Items', 'text_domain'),
        'add_new'            => _x('Add New', 'prefix_portfolio', 'text_domain'),
        'add_new_item'       => __('Add New Item', 'text_domain'),
        'edit_item'          => __('Edit Item', 'text_domain'),
        'new_item'           => __('New Item', 'text_domain'),
        'view_item'          => __('View Item', 'text_domain'),
        'search_items'       => __('Search Items', 'text_domain'),
        'not_found'          => __('No items found.', 'text_domain'),
        'not_found_in_trash' => __('No items found in Trash.', 'text_domain'),
        'parent_item_colon'  => __('Parent Items:', 'text_domain'),
      ),
      'public'        => true,
      'menu_position' => 5,
      'supports'      => array(
        'title',
        'editor',
        'thumbnail',
        'excerpt',
        'custom-fields',
      ),
      'taxonomies'    => array(
        'prefix_portfolio_categories',
      ),
      'has_archive'   => true,
      'rewrite'       => array(
        'slug' => 'portfolio',
      ),
    )
  );
}

add_action('init', 'prefix_register_post_type');


function prefix_register_taxonomy()
{
  register_taxonomy(
    'prefix_portfolio_categories',
    array(
      'prefix_portfolio',
    ),
    array(
      'labels'            => array(
        'name'              => _x('Categories', 'prefix_portfolio', 'text_domain'),
        'singular_name'     => _x('Category', 'prefix_portfolio', 'text_domain'),
        'menu_name'         => __('Categories', 'text_domain'),
        'all_items'         => __('All Categories', 'text_domain'),
        'edit_item'         => __('Edit Category', 'text_domain'),
        'view_item'         => __('View Category', 'text_domain'),
        'update_item'       => __('Update Category', 'text_domain'),
        'add_new_item'      => __('Add New Category', 'text_domain'),
        'new_item_name'     => __('New Category Name', 'text_domain'),
        'parent_item'       => __('Parent Category', 'text_domain'),
        'parent_item_colon' => __('Parent Category:', 'text_domain'),
        'search_items'      => __('Search Categories', 'text_domain'),
      ),
      'show_admin_column' => true,
      'hierarchical'      => true,
      'rewrite'           => array(
        'slug' => 'portfolio/category',
      ),
    )
  );
}

add_action('init', 'prefix_register_taxonomy', 0);

Ви також повинні зареєструвати таксономію під час реєстрації спеціальної пошти.

Після цього запитом буде:

wp-json/wp/v2/posts/?taxonomy=prefix_portfolio_categories'&term=your-any-category

Сподіваюся, це може вам допомогти :)


Дякую мільйон за ваші зусилля щодо цього, але, на жаль, і це не спрацювало. Я впевнений, що я досить близький, але я не розумію, що може бути проблемою. Дякую ще раз
Jeff
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.