• Индусские акробаты на шесте
  • Навигация по звездам за 15 минут
  • Wonderful World теарт теней
  • Будни буржуйского сисадмина
  • Цветовая палитра Yandex
  • Lisa Lavie «Angel»
  • Ричард Фейнман: Резиновые ленты
  • Автомобиль работающий на воде
  • Хоббит
  • Конвертер Youtube видео в MP3
  • Обезьяны и белка
  • Пилонный танец
  • Бесплатный хостинг и домен 2-ого уровня
  • Crayon Physics Deluxe
  • My Brute – игрушка в которой от вас ничего не зависит
  • Wi2Geo запустил бета-тестирование
  • Верблюжий домик
  • Мультитачевый ручной фотошоп
  • Jazzamor – Time Is Running Fast
  • Виртуальная карта MasterCard Prepaid за Яндекс.деньги
  • Тест на логическое мышление
  • Выбери свой стиль
  • 11 января

    Удобный плагин постраничной навигации на jQuery для вашего сайта

    Наконец то я заменил листалку страниц(пейджинг) на этом сайте, на более удобный написанный на jQuery. Называется он Paginator 3000+ и его все чаще можно встретить многих на сайтах.

    Его немного доработал Сергей и опубликовал его на сайте Хабры, а вот тут можно взять его рабочую версию. В ней добавлены кнопки навигации, такие как "Следующая", "Предыдущая", "Первая", "Последняя". При помощи этих кнопок, становится гораздо удобнее перемещаться по страницам.

    Ну и я сразу-же решил прикрутить его к своему сайту при помощи небольшого изменения плагина page_navi для WordPress. И вот как я это сделал.

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

    	<?php if(function_exists('wp_pagenavi')) { ?>
    	<?php echo wp_pagenavi('<noscript>','</noscript>');?>
    	<?php } ?>
    

    В принципе изменения здесь только в добавлении тегов noscript, которые нужны для того, чтобы обернуть в них оригинальный пейджинг от page_navi для которого не требуется наличия Javascipt. В общем если в браузере пользователя отключен Javascript, то будет показан обычный пейджинг, иначе покажется наш новый гламурный Paginator 3000+ на jQuery.

    Далее нам нужно подключить в файле Footer.php вашей темы, где-нибудь в самом низу до тегов </body></html>, Javascipt-код нового пейджинга который мы предварительно должны были скачать здесь. Распаковать и загрузить на сервер все файлы в папочку вашей темы.
    Строки подключения должна выглядеть так:

    <script language="javascript" src="<?php bloginfo('template_directory');?>/jquery-1.3.2.pack.js"></script>
    <script language="javascript" src="<?php bloginfo('template_directory');?>/jquery.paginator.js"></script>
    

    Файла jquery-1.3.2.pack.js – это jQuery библиотека и возможно она уже была подключена в на вашем сайте, по этому попробуйте удалить эту строку и проверить работоспособность пейджинга без нее.

    В файл header.php мы подключаем стили от пейджинга, который называется paginator.css, кстати не забудьте изменить в нему путь к одному изображению(стрелочка). Можно конечно и не подключать отдельно стилевой файл, а просто все, что находится в этом файле скопировать в файл стилей вашей темы, обычно он называется style.css и лежит в папке вашей текущей темы. Второй вариант возможно даже лучше, т.к. чем меньше будет запросов от сайта к файлам на сервере, тем быстрее будет загружаться сайт, но решать в общем вам.

    Строка подключения выглядит так:

    <link href="<?php bloginfo('template_directory');?>/paginator.css" rel="stylesheet" media="all" />
    

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

    Находим строку:

    	echo '</div>'.$after."\n";
    

    И сразу после нее добавляем следующий код:

    ### My paginator 3000
    echo '<script language="javascript">';
    echo "jQuery(document).bind('ready', function (){\n";
    echo "var page = /page\/([^#&\/]*)/.exec(window.location.href);\n";
    echo "var tot = ".$max_page.";\n";
    echo "page = page ? page[1] : 1;\n";
    
    echo "jQuery('#paginator1').paginator({pagesTotal:tot, pagesSpan:10, pageCurrent:page, baseUrl: '".clean_url(get_pagenum_link())."page/'});})\n";
    echo "</script>\n";
    echo '<div class="paginator" id="paginator1"></div>';
    

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

    Вот собственно и все. У меня работает, будет работать и у вас.

    P.S. Немного попользовав данный пейджинг обнаружил пару мелких недоделок. Возможно смогу решить их сам, но лучше бы это сделал автор плагина и тот, кто его модифицировал.

    1. На последней странице не дизаблятся ссылки "Следующая" и "Последняя". Да и находясь именно на первой странице, если кликнуть сначала на любую страницу а потом на первую, то ссылки "Предыдущая" и "Первая" тоже не становятся не активными.
    2. Если в адресной строке после номера страницы идут параметры передающиеся из формы методом GET, например /page/23/?r_sortby=highest_rated&r_orderby=asc, то ссылки в пейджинге будут поставляться уже после параметров и будут выглядеть так: /page/23/?r_sortby=highest_rated&r_orderby=asc/page/24/ и так далее. У меня таким образом работает сортировка записей на сайте.

    Второй пункт более важен для меня и нужно будет подумать как решить данную недоделку.

    Все права на записи принадлежат порталу PION.RU. При использовании любой информации с данного сайта, обратная ссылка «открытая» для поисковых машин на эту страницу обязательна! В противном случае вы нарушатете закон Российской Федерации об авторском праве и смежных правах. Статья 7.3

    Похожие записи:

    1. Browsershots – Проверьте отображение вашего сайта в разных браузерах
    2. Интерактивный редактор кода для jQuery
    3. Таблица безопасных шрифтов для вашего сайта
    4. Плагин для работы с Sape
    5. Схема проезда для сайта при помощи Google Maps
    Распечатать запись Распечатать запись



    Комментарии (7) »

    1. Да не думал я, что меня вот так вот окрестят!
      > некто по имени «Сергей»

      некто по имени "Сергей" оценил запись: некто по имени некто по имени некто по имени некто по имени некто по имени

      комментарий by некто по имени "Сергей"
      — 28 марта 2010 @ 18:14

    2. Наверное надо было писать ник Radik_Wind.

      Pion2er оценил запись: Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5

      комментарий by Pion2er
      — 29 марта 2010 @ 15:08

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

      Сергей оценил запись: Сергей gives a rating of 1Сергей gives a rating of 1Сергей gives a rating of 1Сергей gives a rating of 1Сергей gives a rating of 1

      комментарий by Сергей
      — 13 мая 2010 @ 22:22

    4. Зачем так нервничать. По моему «некто» – совсем не ругательство и странно, что такое обращение могло кого-то оскорбить. Ну да не проблема, мне не сложно отредактировать пост.

      Pion2er оценил запись: Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5

      комментарий by Pion2er
      — 15 мая 2010 @ 09:38

    5. Вот те на,
      это автор пагинатора такой нервный?

      Мне сначала понравилась эта штуковина, уже хотел ставить – теперь не буду.

      Не хочется с психами потом дел иметь :-)

      Евгений еще не оценил запись.

      комментарий by Евгений
      — 15 сентября 2010 @ 18:42

    6. :) ну надо же, значит не только мне так показалось :)

      Pion2er оценил запись: Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5Pion2er gives a rating of 5

      комментарий by Pion2er
      — 17 сентября 2010 @ 10:40

    7. Да, идея изумительная, я вот сам, что-то подобное подумывал стряпать))

      Было бы хорошо ели кто-то из гуру подсказал, как лучше что, где подправить, ибо я в js и php неособо силён :( (, а хочется всего и сразу, чувствую на изучение у меня уйдет года 3 (js and php).

      Заранее Спасибо!!!

      Паразитко))) еще не оценил запись.

      комментарий by Паразитко)))
      — 22 февраля 2011 @ 15:07

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

    RSS лента комментариев на эту запись. TrackBack URL

    1. Подпишись на
      RSS ленту
    2. Pion.ru
      на Twitter
    3. Делись с
      друзьями
    • Любовь и тролли (ремикс)

    •  
      Январь 2010
      Пн Вт Ср Чт Пт Сб Вс
      « Дек   Фев »
       123
      45678910
      11121314151617
      18192021222324
      25262728293031
    • Зарабатываем

    • 221.69 руб. заработано за сутки в бирже ссылок SAPE:
      Место в рейтинге: 119-8

    Как вы относитесь к церкви?

    Результаты

    Loading ... Loading ...