WP REST API получение сообщений из типа post
как я могу получить все сообщения от определенного пользовательского типа сообщения с WP REST API (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
но он возвращает пустой массив (я полагаю, что он возвращает сообщения по умолчанию, и на моем сайте есть только сообщения внутри пользовательского типа post, который я пытаюсь получить).
может ли быть проблема с тем, как я зарегистрировал типа поста?
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' );
любая помощь в этом действительно ценится.
4 ответов
есть действительно выстрел и простой способ для v. 2. Все, что вам нужно сделать, это включить в свой args
массив следующее свойство:'show_in_rest' => true
пример:
register_post_type( 'recipe',
array(
'labels' => $labels,
'public' => true,
'menu_position' => 5,
'hierarchical' => false,
'supports' => $supports,
'show_in_rest' => true,
'taxonomies' => array('recipe-type', 'post_tag'),
'rewrite' => array( 'slug' => __('recipe', 'recipe') )
)
);
register_post_type('имя типа пост'...) не 'add_new' имя. Измените имя типа сообщения на журнал и проверьте результат. Надеюсь, это поможет.
путем возврата к v1 плагина REST API и с /wp-json/posts?type=name-of-post-type
мне удалось получить сообщения из этого конкретного типа сообщения.
для использования V2 плагина REST API:
на функции.в PHP файл вашей темы, добавьте следующее, чтобы создать конечную точку rest:
add_action( 'init', 'add_myCustomPostType_endpoint');
function add_myCustomPostType_endpoint(){
global $wp_post_types;
$wp_post_types['myCustomPostType']->show_in_rest = true;
$wp_post_types['myCustomPostType']->rest_base = 'myCustomPostType';
$wp_post_types['myCustomPostType']->rest_controller_class = 'WP_REST_Posts_Controller';
}
Теперь у вас должна быть следующая конечная точка для запроса:
/wp-json/wp/v2/myCustomPostType
myCustomPostType быть пользовательским типом записи, который вы зарегистрировали. "Rest_base" не должен соответствовать имени пользовательского типа сообщения.
вы, скорее всего, захотите добавить дополнительные поля это относится к вашему настраиваемому типу записи, например метаданным записи или, возможно, из Расширенные Пользовательские Поля плагин. Для этих сценариев вы можете включить эти свойства, добавив такой фрагмент в свой функции.в PHP:
function add_myCustomPostType_fields_url_to_myCustomPostType_request( $data, $post, $request ) {
$_data = $data->data;
$customImageProperty = get_field('customImageProperty');
$_data['customImageProperty'] = $customImageProperty['url'];
$data->data = $_data;
return $data;
}
add_filter( 'rest_prepare_myCustomPostType', 'add_myCustomPostType_fields_url_to_myCustomPostType_request', 10, 3 );