Сортировка get_terms по мета-данным термина
У меня есть пользовательская таксономия prod-cat
Я хочу отсортировать вывод в шаблоне по номеру, поэтому я добавил term_meta к таксономии следующим образом:
add_action( 'prod-cat_add_form_fields', 'add_feature_group_field', 10, 2 );
function add_feature_group_field($taxonomy) {
?>
<div class="form-field term-order-wrap">
<label for="term-order">Порядок</label>
<input type="text" name="wm-cat-prod-order" />
</div>
<?php
}
А затем:
add_action( 'created_prod-cat', 'save_feature_meta', 10, 2 );
function save_feature_meta( $term_id, $tt_id ){
if( isset( $_POST['wm-cat-prod-order'] ) && '' !== $_POST['wm-cat-prod-order'] ){
add_term_meta( $term_id, 'wm-cat-prod-order', $_POST['wm-cat-prod-order'], true );
}
}
Мета-данные термина работают, они сохраняются. Затем в шаблоне я делаю следующее:
$args = array(
'taxonomy' => 'categoria-de-productos',
'orderby' => 'wm-cat-prod-order',
'order' => 'ASC',
'hide_empty' => false,
'hierarchical' => false,
'parent' => 0,
);
$terms = get_terms( $args );
Но я не могу заставить его сортироваться по мета-данным "wm-cat-prod-order". Кто-нибудь может помочь с этим? Спасибо

Функция get_terms
поддерживает параметр meta_query
, который вызывает новый параметр WP_Meta_Query, как вы можете увидеть здесь. Для запроса терминов с нужными метаданными вы можете изменить вызов функции следующим образом:
$args = array(
'taxonomy' => 'categoria-de-productos',
'orderby' => 'meta_value_num',
'order' => 'ASC',
'hide_empty' => false,
'hierarchical' => false,
'parent' => 0,
'meta_query' => [[
'key' => 'wm-cat-prod-order',
'type' => 'NUMERIC',
]],
);
$terms = get_terms( $args );
Этот код не тестировался и, возможно, потребует изменений в вашем случае. Однако предоставленные ссылки должны помочь вам найти решение.

$args = array(
'taxonomy' => 'MY_TAX', // Таксономия
'meta_key' => 'ordem', // Мета-ключ для сортировки
'meta_compare' => 'NUMERIC', // Сравнение как числовое значение
'orderby' => 'meta_value_num', // Сортировка по числовому значению
'order' => 'ASC', // Порядок сортировки (по возрастанию)
'hide_empty' => false, // Показывать пустые термины
);
$the_query = new WP_Term_Query($args); // Создание запроса терминов
foreach ( $the_query->get_terms() as $term ) // Цикл по полученным терминам
{
...
}

Пожалуйста, [отредактируйте] ваш ответ и добавьте объяснение: почему это может решить проблему?

У меня тоже были трудности с этим, и я создал свое мета-поле с помощью ACF. Вот что я сделал, чтобы заставить это работать (некоторые свойства удалены для краткости):
$args = array(
'taxonomy' => 'categoria-de-productos',
'order' => 'ASC',
'orderby' => 'meta_value_num', // Обрабатывать мета-значение как числовое
'meta_key' => 'wm-cat-prod-order' // Ключ мета-поля
);
$terms_query = new WP_Term_Query( $args );
if( ! empty( $terms_query->terms ) ) {
foreach( $terms_query->terms as $term ) {
// Здесь выполняем действия, $term - это объект WP_Term
}
}
Одна из вещей, которые я обычно делаю, это определяю запасной вариант, например 'meta_value_num term_id'
, чтобы использовать term_id
, если значения для wm-cat-prod-order
одинаковы, но это полностью сломало код и привело к неожиданным результатам. Это работало только если 'meta_value_num'
было единственным значением для orderby
.

Для себя я создал пользовательскую таксономию, в которой было пользовательское мета-поле. Мне нужно было добавить колонку в админке и сделать её сортируемой. Чтобы сортировка работала для пользовательского мета-поля в пользовательской таксономии, я сделал следующее.
public function pre_get_terms( $query ) {
$meta_query_args = array(
'relation' => 'AND', // Необязательно, по умолчанию "AND"
array(
'key' => 'order_index',
'value' => 0,
'compare' => '>='
)
);
$meta_query = new WP_Meta_Query( $meta_query_args );
$query->meta_query = $meta_query;
$query->orderby = 'position_clause';
} Ответ я нашёл по этой ссылке https://core.trac.wordpress.org/ticket/34996
Мне просто пришлось адаптировать ответ, предоставленный в комментариях пользователем @eherman24
