Произвольный разделитель в списке страниц

Задача: получить список страниц в следующем виде, используя встроенную в WordPress функцию вывода страниц wp_list_pages():

Контакты | О сайте | Карта сайта

В коде это должно выглядеть следующим образом:

<a href="#">Контакты</a> | <a href="#">О сайте</a> | <a href="#">Карта сайта</a>

По умолчанию хтмл-код списка страниц выглядит примерно так:

<li class="page_item page-item-49"><a href="#" title="Контакты">Контакты</a></li>
<li class="page_item page-item-78"><a href="#" title="О сайте">О сайте</a></li>
<li class="page_item page-item-69"><a href="#" title="Карта сайта">Карта сайта</a></li>

Решение

Содержимое, которое возвращает функция wp_list_pages(), мы с помощью дополнительного параметра echo=0 поместим в переменную, в которой, используя регулярные выражения, сделаем необходимую нам замену тегов.

<?php
$list_pages = wp_list_pages('sort_column=menu_order&title_li=&depth=1&echo=0');
$list_pages = preg_replace('/<\/li>[^>]*<li([^>]*)><a/is', ' | <a$1', $list_pages);
$list_pages = preg_replace('/<li([^>]*)>/is', '', $list_pages);
$list_pages = str_replace('</li>', '', $list_pages);
echo $list_pages;
?>

В результате выполнения этой хитрой замены вышеуказанный список в виде тегов li превратится в такой:

<a class="page_item page-item-49" href="#" title="Контакты">Контакты</a> | <a class="page_item page-item-78" href="#" title="О сайте">О сайте</a> | <a class="page_item page-item-69" href="#" title="Карта сайта">Карта сайта</a>

Получился хтмл-код, которого нам и требовалось добиться.

h++p://wphacks.name/wp-list-pages-custom-separator/

2 комментария

  1. А не проще сделать копию функции wp_list_pages и подогнать ее под свои нужды, чем перегонять по несколько раз несчастный список страниц)

Оставить комментарий

Ваш электронный адрес не будет опубликован.


*


шесть − 4 =