Удаление повторяющихся пользовательских терминов таксономии из выпадающего списка?
У меня есть пользовательский тип записи, который включает пользовательскую таксономию, называемую client_name
. Существует страница, которая загружает эти пользовательские типы записей и отображает их. Что мне нужно разработать, так это раскрывающийся список, в котором отображается вся пользовательская таксономия этих пользовательских сообщений, что я и сделал, но мне нужно удалить дубликаты и расположить их в алфавитном порядке, вот где у меня проблемы.
Вот что я пытаюсь удалить дубликаты (это не работает):
<?php
<form method="post" id="clientform" action="" onsubmit="return getURL(this.url.value)">
<select name="url" id="client">
<option selected="selected">By Client</option>
<?php
$args=array(
'post_type' => 'our_work',
'post_status' => 'publish',
'order' => 'ASC',
'posts_per_page' => -1
);
$my_query = new WP_Query($args);
$k=0;
if( $my_query->have_posts() ) {
while ($my_query->have_posts()) : $my_query->the_post();
$termArray[$k] = array (trim(get_the_term_list( $post->ID, 'client_name')));
// $text = trim(get_the_term_list( $post->ID, 'client_name'));
for ($i = 0; $i <= $termArray.count; $i++ ) {
for ($j = 0; $j <= $tempArray.count; $j++) {
if ($tempArray[$i] == $tempArray[$j]) {
unset($tempArray[$k]);
$termArray = array_values($termArray);
}
} // end of for
$k++;
?><option value="<?php bloginfo('url'); echo "/client_name/"; echo $termArray[$k]; ?>"><?php echo $termArray[$k]; ?></option><?php
} ?>
<?php
endwhile;
}
wp_reset_query();
?>
</select>
<input type="submit" id="clientsubmit" value="Search" />
</form>
Хорошо, теперь я наткнулся на эту функцию PHP на днях, и она делает то, что я хочу, я просто не знаю, как правильно ее использовать.
array_unique($input);
Помогите мне, ребята.... Обратите внимание, что приведенный выше код - это только одна ветвь кода, которую я пробовал, а не весь файл.
ОБНОВЛЕНИЕ
Эй, это действительно немного помогает мне, и я нашел, что это можно использовать, это помогает мне на 95%, но еще не на 100%. Я попробовал ваш код, и я попробовал этот, который я использую, и он удаляет dup, но что угодно это происходит после того, как он не будет отображаться хм....
Вот код WP:
<?php
if( $my_query->have_posts() ) {
while ($my_query->have_posts()) : $my_query->the_post();
$termArray[$i] = trim(get_the_term_list( $post->ID, 'client_name'));
$termArray = array_unique($termArray);
$termArray = array_values($termArray);
print_r($termArray);
print_r(sizeof($termArray));
if ($termArray[$i] != '') {
?><option value="<?php bloginfo('url'); echo "/client_name/"; echo $termArray[$i]; ?>"><?php echo $termArray[$i]; ?></option><?php
}// end of if $i++;
endwhile;
}
wp_reset_query();
И вот вывод из массива, он дублирует вывод массива, потому что он вызывается каждый раз, когда в цикле вызывается новая запись. Страница доступна здесь:
Просмотрите источник, чтобы понять, что я имею в виду.
1 answers
Привет@Хантер Брелсфорд:
Рад видеть вас здесь из группы WordPress в LinkedIn.
Может быть, я неправильно понял ваш вопрос, но похоже, что вы просто пытаетесь избавиться от дубликатов в массиве? Например, допустим, у вас есть клиенты массива:
<?php
$clients = array(
'Jones Construction',
'Smith Wholesale',
'Smith Wholesale',
'Williams Dry Cleaning'
);
И вы хотите преобразовать в такой массив?
<?php
$clients = array(
'Jones Construction',
'Smith Wholesale',
'Williams Dry Cleaning'
);
( Если да, то это вопрос PHP, а не вопрос WordPress, обычно что-то мы отправляйте, но я все равно продолжу и отвечу здесь.)
Это просто; так как ключи массива уникальны в PHP, просто переверните массив (обменяйте значения их ключами), затем верните ключи массива, и у вас будет свой уникальный массив, вот так:
<?php
$clients = array(
'Jones Construction',
'Smith Wholesale',
'Smith Wholesale',
'Williams Dry Cleaning'
);
print_r(array_keys(array_flip($clients)));
Этот код выводит:
Array
(
[0] => Jones Construction
[1] => Smith Wholesale
[2] => Williams Dry Cleaning
)
Это было то, чего ты добивался?
ОБНОВЛЕНИЕ:
Привет@Хантер Брелсфорд:
Я отвечаю на ваше обновление. Хорошо, почему бы нам не попробовать решить эту проблему по-другому путь? Вот отдельный пример, который вы можете скопировать в корневой каталог своего веб-сайта как test.php
, а затем запустить его как http://magicvideo.com/test.php
чтобы увидеть, как это работает:
<?php
include "wp-load.php";
header('Content-Type:text/plain');
global $wpdb;
$sql = <<<SQL
SELECT DISTINCT
tt.term_id
FROM {$wpdb->posts} p
INNER JOIN {$wpdb->term_relationships} tr ON p.ID = tr.object_id
INNER JOIN {$wpdb->term_taxonomy} tt ON tt.term_taxonomy_id = tr.term_taxonomy_id
WHERE 1=1
AND p.post_status='publish'
AND p.post_type='our_work'
AND tt.taxonomy='client_name'
SQL;
$terms = $wpdb->get_results($sql);
$term_ids = array();
foreach($terms as $term) {
$term_ids[] = $term->term_id;
}
$terms = get_terms('client_name',array(
'include'=> implode(',',$term_ids),
));
print_r($terms);
Мы используем необработанный SQL для запроса терминов в taxonomy='client_name'
для 'post_type='our_work'
, а затем собираем $term->term_id
для фильтрации списка терминов таксономии. Я использовал необработанный SQL, потому что WordPress не предоставляет хорошего способа получения этих данных через API, по крайней мере, я не мог найти его в кратчайшие сроки (, если кто-то еще знает лучший способ с помощью API, который не требует загрузка намного большего количества данных, чем необходимо, пожалуйста, дайте мне знать).
Надеюсь, это подскажет подход, с помощью которого вы сможете использовать этот код в своем примере? Дайте мне знать, если знаете, если нет.