WordPress как на ладони
Недорогой хостинг для сайтов на WordPress: wordpress.jino.ru Купить персональные IPV4 и IPV6 прокси

Альтернатива плагину WP-pagenavi (пагинация для WordPress)

C версии 4.1 в WordPress появилась родная аналогичная функция: the_posts_pagination()

Попалась мне как-то тема, что популярнейший  плагин WordPress wp-pagenavi нагружает сервер не в меру своей надобности. Проанализировав его код выяснил, что это всего лишь миф, хотя его все же можно немного оптимизировать, собственно этому и посвящен пост.

Если другие плагины сложно представить без возможности их настройки в админ-панели, то wp-pagenavi мне представляется легко. Достаточно один раз настроить навигацию и забыть про нее. И наверное есть те, кто думает так же? Поэтому я решил отказаться от wp-pagenavi и заменить его на свою функцию. Функцию я написал, предварительно изучив код wp-pagenavi, частично код был взят от туда. Все CSS классы wp-pagenavi сохранены и, как следствие, заменить wp-pagenavi на мой вариант совсем не составит труда.

Для замены нужно скопировать нижеследующую функцию в файл шаблона functions.php. Также, нужно скопировать CSS стили wp-pagenavi в ваш файл стилей (обычно это style.css). Перенос стилей носит и полезный характер, потому что больше не будет необходимости подключать файл стилей, а это минус один http запрос.

/**
 * Альтернатива wp_pagenavi. Создает ссылки пагинации на страницах архивов.
 *
 * @param array  $args      Аргументы функции
 * @param object $wp_query  Объект WP_Query на основе которого строится пагинация. По умолчанию глобальная переменная $wp_query
 *
 * @version 2.7
 * @author  Тимур Камаев
 * @link    Ссылка на страницу функции: http://wp-kama.ru/?p=8
 */
function kama_pagenavi( $args = array(), $wp_query = null ){

	// параметры по умолчанию
	$default = array(
		'before'          => '',   // Текст до навигации.
		'after'           => '',   // Текст после навигации.
		'echo'            => true, // Возвращать или выводить результат.

		'text_num_page'   => '',           // Текст перед пагинацией.
		// {current} - текущая.
		// {last} - последняя (пр: 'Страница {current} из {last}' получим: "Страница 4 из 60").
		'num_pages'       => 10,           // Сколько ссылок показывать.
		'step_link'       => 10,           // Ссылки с шагом (если 10, то: 1,2,3...10,20,30. Ставим 0, если такие ссылки не нужны.
		'dotright_text'   => '…',          // Промежуточный текст "до".
		'dotright_text2'  => '…',          // Промежуточный текст "после".
		'back_text'       => '« назад',    // Текст "перейти на предыдущую страницу". Ставим 0, если эта ссылка не нужна.
		'next_text'       => 'вперед »',   // Текст "перейти на следующую страницу".  Ставим 0, если эта ссылка не нужна.
		'first_page_text' => '« к началу', // Текст "к первой странице".    Ставим 0, если вместо текста нужно показать номер страницы.
		'last_page_text'  => 'в конец »',  // Текст "к последней странице". Ставим 0, если вместо текста нужно показать номер страницы.
	);

	// Cовместимость с v2.5: kama_pagenavi( $before = '', $after = '', $echo = true, $args = array() )
	if( ($fargs = func_get_args()) && is_string( $fargs[0] ) ){
		$default['before'] = isset($fargs[0]) ? $fargs[0] : '';
		$default['after']  = isset($fargs[1]) ? $fargs[1] : '';
		$default['echo']   = isset($fargs[2]) ? $fargs[2] : true;
		$args              = isset($fargs[3]) ? $fargs[3] : array();
		$wp_query = $GLOBALS['wp_query']; // после определения $default!
	}

	if( ! $wp_query ){
		wp_reset_query();
		global $wp_query;
	}

	if( ! $args ) $args = array();
	if( $args instanceof WP_Query ){
		$wp_query = $args;
		$args     = array();
	}

	$default = apply_filters( 'kama_pagenavi_args', $default ); // чтобы можно было установить свои значения по умолчанию

	$rg = (object) array_merge( $default, $args );

	//$posts_per_page = (int) $wp_query->get('posts_per_page');
	$paged          = (int) $wp_query->get('paged');
	$max_page       = $wp_query->max_num_pages;

	// проверка на надобность в навигации
	if( $max_page <= 1 )
		return false;

	if( empty( $paged ) || $paged == 0 )
		$paged = 1;

	$pages_to_show = intval( $rg->num_pages );
	$pages_to_show_minus_1 = $pages_to_show-1;

	$half_page_start = floor( $pages_to_show_minus_1/2 ); // сколько ссылок до текущей страницы
	$half_page_end   = ceil(  $pages_to_show_minus_1/2 ); // сколько ссылок после текущей страницы

	$start_page = $paged - $half_page_start; // первая страница
	$end_page   = $paged + $half_page_end;   // последняя страница (условно)

	if( $start_page <= 0 )
		$start_page = 1;
	if( ($end_page - $start_page) != $pages_to_show_minus_1 )
		$end_page = $start_page + $pages_to_show_minus_1;
	if( $end_page > $max_page ) {
		$start_page = $max_page - $pages_to_show_minus_1;
		$end_page = (int) $max_page;
	}

	if( $start_page <= 0 )
		$start_page = 1;

	// создаем базу чтобы вызвать get_pagenum_link один раз
	$link_base = str_replace( 99999999, '___', get_pagenum_link( 99999999 ) );
	$first_url = get_pagenum_link( 1 );
	if( false === strpos( $first_url, '?') )
		$first_url = user_trailingslashit( $first_url );

	// собираем елементы
	$els = array();

	if( $rg->text_num_page ){
		$rg->text_num_page = preg_replace( '!{current}|{last}!', '%s', $rg->text_num_page );
		$els['pages'] = sprintf( '<span class="pages">'. $rg->text_num_page .'</span>', $paged, $max_page );
	}
	// назад
	if ( $rg->back_text && $paged != 1 )
		$els['prev'] = '<a class="prev" href="'. ( ($paged-1)==1 ? $first_url : str_replace( '___', ($paged-1), $link_base ) ) .'">'. $rg->back_text .'</a>';
	// в начало
	if ( $start_page >= 2 && $pages_to_show < $max_page ) {
		$els['first'] = '<a class="first" href="'. $first_url .'">'. ( $rg->first_page_text ?: 1 ) .'</a>';
		if( $rg->dotright_text && $start_page != 2 )
			$els[] = '<span class="extend">'. $rg->dotright_text .'</span>';
	}
	// пагинация
	for( $i = $start_page; $i <= $end_page; $i++ ) {
		if( $i == $paged )
			$els['current'] = '<span class="current">'. $i .'</span>';
		elseif( $i == 1 )
			$els[] = '<a href="'. $first_url .'">1</a>';
		else
			$els[] = '<a href="'. str_replace( '___', $i, $link_base ) .'">'. $i .'</a>';
	}

	// ссылки с шагом
	$dd = 0;
	if ( $rg->step_link && $end_page < $max_page ){
		for( $i = $end_page + 1; $i <= $max_page; $i++ ){
			if( $i % $rg->step_link == 0 && $i !== $rg->num_pages ) {
				if ( ++$dd == 1 )
					$els[] = '<span class="extend">'. $rg->dotright_text2 .'</span>';
				$els[] = '<a href="'. str_replace( '___', $i, $link_base ) .'">'. $i .'</a>';
			}
		}
	}
	// в конец
	if ( $end_page < $max_page ) {
		if( $rg->dotright_text && $end_page != ($max_page-1) )
			$els[] = '<span class="extend">'. $rg->dotright_text2 .'</span>';
		$els['last'] = '<a class="last" href="'. str_replace( '___', $max_page, $link_base ) .'">'. ( $rg->last_page_text ?: $max_page ) .'</a>';
	}
	// вперед
	if ( $rg->next_text && $paged != $end_page )
		$els['next'] = '<a class="next" href="'. str_replace( '___', ($paged+1), $link_base ) .'">'. $rg->next_text .'</a>';

	$els = apply_filters( 'kama_pagenavi_elements', $els );

	$out = $rg->before . '<div class="wp-pagenavi">'. implode( ' ', $els ) .'</div>'. $rg->after;

	$out = apply_filters( 'kama_pagenavi', $out );

	if( $rg->echo ) echo $out;
	else return $out;
}
/**
 * 2.7 (02.11.2018) - В $args можно указать второй параметр $wp_query, когда $args можно оставить пустым.
 *                  - Правки кода - исправил баги, переделал сбор элементов в массив.
 *                  - Новый хук `kama_pagenavi_elements`.
 * 2.6 (20.10.2018) - Убрал extract().
 *                  - Перенес параметры $before, $after, $echo в $args (старый вариант будет работать).
 * 2.5 - 2.5.1      - Автоматический сброс основного запроса.
 */

Настройки описаны прямо в коде и они идентичны настройкам wp-pagenavi, с той лишь разницей, что вместо текста "к последней странице" можно вывести номер последней страницы.

После того, как функция установлена и css стили перенесены, меняем в шаблоне код wp_pagenavi на этот:

<?php kama_pagenavi(); ?>

Если у вас в коде что-то вроде этого, то нужно поменять все wp_pagenavi на kama_pagenavi:

if(function_exists('wp_pagenavi')) {
	wp_pagenavi( '<center>', '</center>' );
}

CSS стили для кода

Выше я уже сказал. что классы CSS совпадают с wp-pagenavi. Для удобства выкладываю тут все CSS правила:

.wp-pagenavi{ margin:2em auto; text-align:center; }
.wp-pagenavi > *{ display:inline-block; padding:.0em .5em; margin:.1em; border:1px solid #93a8bc; border-radius:3px; color:#465366; }
.wp-pagenavi a,
	.wp-pagenavi a:hover{ text-decoration:none; }
.wp-pagenavi a{ background-color: #FFFFFF; }
.wp-pagenavi a:hover{ border-color:#7d95ac; }
.wp-pagenavi .pages{ }
.wp-pagenavi .current{ border-color:#465366; color: #465366; }
.wp-pagenavi .extend{ color: #465366; }
.wp-pagenavi .first{  }
.wp-pagenavi .last{  }
.wp-pagenavi .prev{ border-color:rgba(0,0,0,0); }
.wp-pagenavi .next{ border-color:rgba(0,0,0,0); }

В моем коде присутствуют 4 новых класса: first (в начало), last (в конец), prev (назад), next (вперед).

Неплохую подборку стилей можно взять здесь.

Если навигация выводится 2 раза

Так же, хочу обратить внимание тех, у кого навигация выводится 2 раза на странице (сверху и снизу цикла). Чтобы 2 раза не выполнять одни и те же операции по составлению навигации, логичнее сделать так: один раз собрать навигацию (использовать функцию), затем записать результат в переменную и второй раз просто вывести эту переменную. Выглядит это так:

// место, где первый раз нужно вывести навигацию
// получаем навигацию и записываем её в переменную
$navigation = kama_pagenavi('', '', false);
// выводим переменную на экран
echo $navigation; 

		/* Здесь идет вывод постов - цикл Loop */

// место, где второй раз нужно вывести навигацию.
//Так как навигация уже записана в переменную $get_navigation, её можно просто вывести на экран.
echo $navigation;

Обновления

17 декабря 2013
Версия 2.0. Подправил код, убрал лишние, ненужные вызовы функции get_pagenum_link(), за счет чего код стал работать гораздо быстрее, без потери качества.

11 мая 2010
Перенес ссылки назад/вперед, теперь так:
«назад «**к началу ... 11 12 13 14 15 16 17 18 ... в конец**» вперед»

Последний вариант функции наверху.

2 мая 2010

  1. Добавлены ссылки назад/вперед, пример:
    «**к началу «назад ... 11 12 13 14 15 16 17 18 ... вперед» в конец**»
    Их можно отключить (см. настройки).

  2. Убран баг такого типа:
    1 ... 2 3 4 5 6 7 8 ... 50 или 1 ... 21 22 23 24 25 26 27 28 ... 29
    То есть, где не нужно убраны тексты "до" и "после" навигации (в данном примере это троеточие).

Реверсивная пагинация для WordPress

Идея реверсивной (обратной) пагинации принадлежит sholo, который высказал её на известном нам форуме - mywordpress.ru. Мне стало интересно посмотреть, как это будет выглядеть и я немного переделал код.

Этот код основан на старой версии основного кода...

/* Альтернатива wp_pagenavi - реверсивная пагинация
--------------------------------------------------------------------------------- */
function kama_pagenavi($before='', $after='', $echo=true) {
	/* ================ Настройки ================ */
	$text_num_page = ''; // Текст для количества страниц. {current} заменится текущей, а {last} последней. Пример: 'Страница {current} из {last}' = Страница 4 из 60
	$num_pages = 10; // сколько ссылок показывать
	$stepLink = 10; // после навигации ссылки с определенным шагом (значение = число (какой шаг) или '', если не нужно показывать). Пример: 1,2,3...10,20,30
	$dotright_text = '…'; // промежуточный текст "до".
	$dotright_text2 = '…'; // промежуточный текст "после".
	$backtext = '<<<'; // текст "перейти на предыдущую страницу". Ставим '', если эта ссылка не нужна.
	$nexttext = '>>>'; // текст "перейти на следующую страницу". Ставим '', если эта ссылка не нужна.
	$first_page_text = '« последняя'; // текст "к первой странице" или ставим '', если вместо текста нужно показать номер страницы.
	$last_page_text = 'первая »'; // текст "к последней странице" или пишем '', если вместо текста нужно показать номер страницы.
	/* ================ Конец Настроек ================ */ 

	global $wp_query;
	$posts_per_page = (int) $wp_query->query_vars['posts_per_page'];
	$paged = (int) $wp_query->query_vars['paged'];
	$max_page = $wp_query->max_num_pages;

	if($max_page <= 1 ) return false; //проверка на надобность в навигации

	if(empty($paged) || $paged == 0) $paged = 1;

	$pages_to_show = intval($num_pages);
	$pages_to_show_minus_1 = $pages_to_show-1;

	$half_page_start = floor($pages_to_show_minus_1/2); //сколько ссылок до текущей страницы
	$half_page_end = ceil($pages_to_show_minus_1/2); //сколько ссылок после текущей страницы

	$start_page = $paged - $half_page_start; //первая страница
	$end_page = $paged + $half_page_end; //последняя страница (условно)

	if($start_page <= 0) $start_page = 1;
	if(($end_page - $start_page) != $pages_to_show_minus_1) $end_page = $start_page + $pages_to_show_minus_1;
	if($end_page > $max_page) {
		$start_page = $max_page - $pages_to_show_minus_1;
		$end_page = (int) $max_page;
	}

	if($start_page <= 0) $start_page = 1;

	$out='';//выводим навигацию
		$out.= $before."<div class='wp-pagenavi'>\n";
				if ($text_num_page){
					$text_num_page = preg_replace ('!{current}|{last}!','%s',$text_num_page);
					$out.= sprintf ("<span class='pages'>$text_num_page</span>",$paged,$max_page);
				}

				if ($backtext && $paged!=1) $out.= '<a href="'.get_pagenum_link(($paged-1)).'">'.$backtext.'</a>';

				if ($start_page >= 2 && $pages_to_show < $max_page) {
					$out.= '<a href="'.get_pagenum_link().'">'. ($first_page_text?$first_page_text:$max_page) .'</a>';
					if($dotright_text && $start_page!=2) $out.= '<span class="extend">'.$dotright_text.'</span>';
				}

				for($i = $start_page; $i <= $end_page; $i++) {
					if($i == $paged) {
						$out.= '<span class="current">'.($max_page-$i+1).'</span>';
					} else {

						$out.= '<a href="'.get_pagenum_link($i).'">'.($max_page-$i+1).'</a>';
					}
				}

				//ссылки с шагом
				if ($stepLink && $end_page < $max_page){
					for($i=$end_page+1; $i<=$max_page; $i++) {
						if($i % $stepLink == 0 && $i!==$num_pages) {
							if (++$dd == 1) $out.= '<span class="extend">'.$dotright_text2.'</span>';
							$out.= '<a href="'.get_pagenum_link($i).'">'.($max_page-$i+1).'</a>';
						}
					}
				}

				if ($end_page < $max_page) {
					if($dotright_text && $end_page!=($max_page-1)) $out.= '<span class="extend">'.$dotright_text2.'</span>';
					$out.= '<a href="'.get_pagenum_link($max_page).'">'. ($last_page_text?$last_page_text:1) .'</a>';
				}

				if ($nexttext && $paged!=$end_page) $out.= '<a href="'.get_pagenum_link(($paged+1)).'">'.$nexttext.'</a>';

		$out.= "</div>".$after."\n";
	if ($echo) echo $out;
	else return $out;
}
206 комментов
Полезные 7 Вопросы 3 Все
  • Dimox dimox.name

    Спасибо за функцию, обязательно попробую. В данный момент юзаю вот такую - http://iskariot.ru/development/own-pagenavi/

    P.S. Понравился блог smile Подписался.

    Ответить9.2 лет назад #
    • Kama7539

      Спасибо за комментарий! Мне когда-то твой блог очень помог, ну и сейчас полезен весьма smile

      Глянул вариант на iskariot.ru - почти тоже самое, только там настроек нет и не доработано, автор поленился ведать.

      И еще, судя по коду, там нет деления до текущей и после текущей страницы, т.е. если указано выводить 10 ссылок, то будут выводится 10 до текущей и 10 после, итого 20. Когда с кодом pagenavi разбирался, сначала не понял зачем такое деление нужно smile

      Ответить9.2 лет назад #
      • Dimox dimox.name

        И еще, судя по коду, там нет деления до текущей и после текущей страницы, т.е. если указано выводить 10 ссылок, то будут выводится 10 до текущей и 10 после, итого 20.

        Вот мне как раз этого и не хватало в коде искариота. Я пытался сам эту проблему решить, но у меня толком ничего не вышло, плоховато в PHP разбираюсь.

        Спасибо тебе, что учел эту особенность! Скорее всего, теперь буду использовать твою функцию. Единственное, чего не хватает - ссылок "следующая/предыдущая". Но, я думаю, сам это смогу "допилить".

        P.S. И спасибо за отзыв о моем блоге ;0)

        Ответить9.2 лет назад #
        • Kama7539

          Единственное, чего не хватает - ссылок "следующая/предыдущая".

          Я спец. вырезал назад/вперед. Зачем они? Я почему-то никогда ими не пользовался, нигде - всегда по цыфрам нажимал.

          P.S. И спасибо за отзыв о моем блоге ;0)

          Если бы я этого не сделал, я бы себя плохо чувствовал... smile Один из лучших блогов на мой взгляд, а если с точки зрения оформления смотреть, то лучше блога я чет не припомню smile

          Ответить9.2 лет назад #
          • Dimox dimox.name

            Я спец. вырезал назад/вперед. Зачем они?

            Для меня это вроде как стандарт. Я уже привык, что они есть (хоть даже и не использую тоже), и когда шаблоны на заказ верстаю, там они тоже всегда присутствуют.

            В общем, я уже их сделал себе, можешь на моем блоге увидеть.

            Если бы я этого не сделал, я бы себя плохо чувствовал... Один из лучших блогов на мой взгляд, а если с точки зрения оформления смотреть, то лучше блога я чет не припомню

            Спасибо большое! smile

            Ответить9.2 лет назад #
  • Dimox dimox.name

    Вот еще что обнаружил - http://i066.radikal.ru/1004/ad/2d3ec2efa24b.jpg

    Т.е. троеточие стоит между 1 и 2 (а оно здесь лишнее), и точно так же, если с конце смотреть.

    Ответить9.2 лет назад #
    • Kama7539

      Я видел этот баг. У самого pagenavi тоже самое, там просто вот так:

      вполне нормально смотрится. Поправлю сегодня, завтра и назад/вперед добавлю тоже, с возможностью отказаться от них.

      Ответить9.2 лет назад #
      • Dimox dimox.name

        Да в общем-то, это и не принципиально.

        Ответить9.2 лет назад #
  • Kama7539

    Обновил функцию

    Ответить9.2 лет назад #
  • seezer blog.seezer.ru

    (Этот коммент очень похож на спамерский, но не знаю как иначе :)!)
    Среди кучи блогов, посвященных WP, этот как-то особо зацепил. Завел подписку в GReader.

    Ответить9.2 лет назад #
  • Iceman www.cms-systems.ru

    Еще бы подписку через Твиттер на блоге сделать, чтобы анонсы новых статей можно было получать)

    Ответить9.2 лет назад #
    • Kama7539

      Сделаю smile А RSS в тивитер сунуть не получится чтоли?

      Ответить9.2 лет назад #
      • Iceman www.cms-systems.ru

        Получиться, конечно) RSS прикручиваете к Твиттеру и можете о нем забыть навсегда. А кому удобно будет - тот будет получать анонсы постов в Твиттер)

        Ответить9.2 лет назад #
      • Iceman www.cms-systems.ru

        P.S. Я на Ваш сайт попал через Твиттер, кстати говоря) Dimox написал об это плагине.

        Ответить9.2 лет назад #
        • Kama7539

          Dimox написал об это плагине.

          Я знаю smile Диме за это спасибо!

          Уже прикрутил RSS smile Вот мой твит: twitter.com/www_kama.

          Вчера еще не знал, что такое твиттер smile Поэтому такие вопросы smile

          Ответить9.2 лет назад #
  • Mike

    и в чем же преимущество вашего плагина?

    похоже на те же яйца, только в профиль.

    1-2 запроса ничего не решают, к тому же запросы к кэшу можно опустить.

    вот такие вот посты рождаются в блогах, когда авторы называются именами велосипедов laugh

    http://images04.olx.ru/ui/1/80/67/13407367_1.jpg

    Ответить9.2 лет назад #
    • Kama7539

      вот такие вот посты рождаются в блогах ...

      Аахаха, ага laugh А еще, рождаются такие вот блоги. А вообще, как говорится, - "Не нравится? не ешь!" smile.

      Если можно убрать лишние запросы к кешу, убрать лишние обращения к серверу, убрать еще один плагин, в меню плагинов, в админке. То, я считаю, что было бы неплохо это сделать!

      Я никого не призываю обязательно ставить эту функцию и не утверждаю, что эта функция гораздо быстрее плагина wp-pagenavi, хотя она все-таки хоть немного, да быстрее и сейчас она чуть-чуть функциональнее wp-pagenavi.

      Просто, мне было интересно сделать такую функцию, вот я её и сделал, для себя я что-то понял, чему-то научился.

      К тому же, этот пост может не прямо а косвенно помочь кому-то, что-то понять или освоить (я о тех, кто к этому стремится). У меня так не раз было, в частности на сайтах Dimox'a и Максима - читаю пост по одной теме, просматриваю коды и понимаю как сделать что-то другое или как использовать некоторые моменты в другом месте или просто узнаю то, чего до этого не знал.

      Короче, это пост не менее теоритический, чем практический smile

      Ответить9.2 лет назад #
      • Kama7539

        похоже на те же яйца, только в профиль.

        Обновил статью, теперь появились еще яйца, все те же, но уже с тыла laugh

        Ответить9.2 лет назад #
  • ADv lastfmtools.ru

    попробовал установить код. все "как бы" получилось, за исключением того, что находясь на первой странице, внизу отображается цифра 2. находясь на 2й - единица. брал первый код, который не реверсивный. хелп smile

    Ответить9 лет назад #
    • Kama7539

      Очень странно, так вообще не должно быть. Проверьте, точно не реверсинвый код вставляли, а то что-то из области фантастики получается.

      Ответить9 лет назад #
  • Наблюдатель www.blog-rv.com

    Тимур, спасибо, постраничка работает отлично. После всех исправлений не заметил ни одного косяка, все корректно.
    Да и грузится блог вроде быстрее. Вообщем, спасибо.

    Ответить8.7 лет назад #
  • cardsmoney

    вот обратная нумерация.. как вы её реализовали? не оч охота 70 строк кода сравнивать..
    спасибо

    Ответить8.6 лет назад #
    • Kama7539

      Просто поменял анкор ссылки. В нормальном там показывается по порядку, а в реверсивной (всего страниц - номер текущей) ($max_page-$i+1). Грубо говоря, так.

      Ответить8.6 лет назад #
      • Антон yaponomat.com

        По сути ничего не поменялось, смысла в этом действе 0, вот если бы вы сделали полный рекурсив, типа главная страница - это 17-ая в системе, а самая старая страница которая раньше была 17-ой, становится 1-ой. Тоесть контент на данных страницах меняться не будет и соотв. поисковики не будут сходить с ума при постинге новой новости.

        Ответить5.7 лет назад #
  • cardsmoney

    да , кстати.. опять же насчёт реверсивной навигации

    Сами страницы wp нумеруются автоматически в виде site.ru/?paged=1. И порядок этот опять таки неправильный..

    поесть несовпадение получается. .

    наверное проще просто поменять порядок страниц в wp ?

    Ответить8.6 лет назад #
    • Kama7539

      И порядок этот опять таки неправильный..

      Ну эт смотря с какой точки зрения смотреть. Он такой же неправильный, как и правильный wacko

      Порядок страниц в движке поменять совсем не проще - это ваще другая история! На этом порядке запросы к БД построены и еще много чего (не разбирался). Я конечно люблю авантюры, но не настолько sarcastic

      Ответить8.6 лет назад #
Здравствуйте, !     Войти . Зарегистрироваться