Estoy tratando de verificar por el título de una publicación si la publicación existe o no. Por alguna razón, cuando intento algo como:
http://domain.com/wp-json/wp/v2/posts?filter[post-title]=table
Si existe una publicación con la tabla de nombres, quiero obtener la publicación; si no, obtener una respuesta vacía. Pero por alguna razón, cuando la publicación con título no existe, recupero todas las publicaciones. ¿Cómo podría quedar vacío cuando no existe una publicación y la publicación cuando existe?
Negro
Desafortunadamente no es posible, pero puedes usar slug en su lugar. Slug es una parte editable de la URL al escribir una publicación y puede representar el título de la página (o se puede cambiar a esto).
http://example.com/wp-json/wp/v2/posts?slug=table
Más detalles:
https://developer.wordpress.org/rest-api/reference/pages/#arguments
De acuerdo a http://v2.wp-api.org/algunos tienen que usar search
palabra clave :
http://domain.com/wp-json/wp/v2/posts?search=table
.
-
El problema es que esto devolverá cualquier publicación que contenga la palabra clave en el contenido, no solo el título.
– John Dee
18 de diciembre de 2018 a las 7:54
No puede hacer esto a través de wp json, copie el siguiente código en functions.php:
function __search_by_title_only( $search, &$wp_query ) {
global $wpdb;
if ( empty( $search ) )
return $search; // skip processing - no search term in query
$q = $wp_query->query_vars;
$n = ! empty( $q['exact'] ) ? '' : '%';
$search =
$searchand = '';
foreach ( (array) $q['search_terms'] as $term ) {
$term = esc_sql( like_escape( $term ) );
$search .= "{$searchand}($wpdb->posts.post_title LIKE '{$n}{$term}{$n}')";
$searchand = ' AND ';
}
if ( ! empty( $search ) ) {
$search = " AND ({$search}) ";
if ( ! is_user_logged_in() )
$search .= " AND ($wpdb->posts.post_password = '') ";
}
return $search;
}
add_filter( 'posts_search', '__search_by_title_only', 500, 2 );
tengo el mismo problema y no he encontrado ninguna solución…
– Michael Perrin
16 de noviembre de 2015 a las 15:11