Задача: получить список страниц в следующем виде, используя встроенную в 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/

Категория: PHP, HTML, CSS... | Теги:

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

  1. Артем | 3.03.2011

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

  2. Макс | 3.03.2011

    Вы забыли добавить «А потом каждый раз при добавлении или удалении этой страницы лазить и все править…»

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