Плагин WP-PostRatings рейтинга постов в WordPress
Опубликовано: 01.09.2018
По планам на 2011 я решил полностью модернизировать и настроить некоторые свои блоги в соответствии с личными пожелания. Вместе с этим недавно на хостинге, который использую для парочки своих проектов HostPro начались небольшие подтормаживания. У них там были вроде как технические работы или что-то около, после чего ситуация стабилизировалась, но я все же решил заняться оптимизацией самих блогов. Посудите сами 8 сайтов на одном аккаунте, парочка из которых с посещениями под 1-2к уников это ли не нагрузка. Начал я, конечно, же с кэширование в wordpress так как это достаточно простой и доступный способ провести оптимизацию загрузки страницы. Учитывая, что никакие ссылки на белых проектах я не продаю, проблем с использованием WP Super Cache (выбранного мной для работы) быть не должно.
Еще одним важным моментом в оптимизации работы блога есть подборка плагинов. Ни для кого не секрет, что некоторые модули могут здорово загрузить ваш проект и быть причиной тормозов на сайте. Одним из таких тяжелых плагинов, к сожалению, оказался WP-PostViews для определения наиболее популярных (просматриваемых) материалов блога. Сначала не мог понять откуда может быть нагрузка у простого, казалось бы, модуля, но в комментариях мне все же советовали отказаться от него. Насколько я понимаю, каждое посещение пользователя пишется в базу данных дабы потом подбивать статистику — отсюда во-первых, дополнительная нагрузка на БД (если онлайн, допустим человек 5-10), во-вторых, «захламление» таблиц БД не столь важной информацией.
Рейтинг постов в WordPress
Короче говоря, было принято волевое решение для посещаемых блогов отказаться от использования WP-PostViews в пользу другого не менее интересного модуля — WP-PostRatings . Это рейтинговая система на AJAX для оценки статей и страниц wordpress сайта. После установки плагина пользователи смогут выставлять оценки (положительные, отрицательные либо количественные) к записям проекта. Основное преимущество WP-PostRatings это, конечно, возможность, выразить свое непосредственно отношение к публикациям сайта, то есть отметить нравится она или нет. Это действие подразумевает наличие определенной «не пассивно» аудитории проекта, которая бы оценивала ваши труды. Меня всегда пугали сайты, где красовались 2-3 оценки для статьи и все, возникает ощущение «неживого» блога. В то же время модуль WP-PostViews позволял просто выводить ссылки на популярные статьи, не нужно было никаких оценок и реакции посетителей. Тем не менее, из-за большой нагрузки все же склоняюсь к WP-PostRatings, при посещаемости в 1000-2000 уников за пару месяцев «набьете» оценки для постов, как новых, так и некоторых старых.
Adding a Post Rating System in WordPress with WP PostRatings
Установка и настройка WP-PostRatings
Скачать плагин WP-PostRatings можно здесь . Процесс установки его максимально прост — как обычно, разархивируем и заливаем на ФТП в папку wp-content/plugins , после чего Активируем WP-PostRatings в админке wordpress.
После установки в админке появится блок Ratings, где можно:
Manage Ratings — просматривать результаты оценок для статьей, делать выборки и удалять результаты. Ratings Options — указывать некоторые настройки модуля. Rating Templates — задавать шаблон отображения результатов и голосования. Uninstall WP-PostRatings — удалить плагин.В настройках вы можете выбрать различные варианты того, как будет отображаться оценивание — будь то обычный «+» и «-» либо количественная оценка в виде «звездочек». Их число, кстати, можно указывать такое как вам нужно.
Если хотите чтобы для изображений использовался не GIF формат, а PNG, то в файле wp-content/plugins/wp-postratings/wp-postratings.php нужно найти строки:
define('RATINGS_IMG_EXT', 'gif'); //define('RATINGS_IMG_EXT', 'png'); |
define('RATINGS_IMG_EXT', 'gif'); //define('RATINGS_IMG_EXT', 'png');
И закомментировать (добавить //) первую из них, а у второй слэши убрать. После возвращаетесь в админку в меню Ratings Options и отмечаете один единственный «вариант со звездочками» для PNG.
Следующий шаг — добавить отображение опроса в блог. Для этого открываем файл шаблона, где ходим его добавить — отдельный пост (single.php), архив (archive.php) и т.п. Далее в коде пишем:
<?php if ( function_exists ( 'the_ratings' ) ) { the_ratings ( ) ; } ?> |
<?php if(function_exists('the_ratings')) { the_ratings(); } ?>
Для файлов шаблона с выводом перечня постов (главная, архив) нужно располагать код внутри цикла Loop, то есть где-то после:
<?php if ( have_posts ( ) ) : while ( have_posts ( ) ) : the_post ( ) ; ?> |
<?php if (have_posts()) : while (have_posts()) : the_post(); ?>
Проще всего сориентироваться для начинающих — это добавить вызов функции рядом с отображением названия категории и тегов, тогда все точно будет работать. Также плагин WP-PostRatings поддерживает виджеты.
Чтобы вывести результаты опроса читательского мнения нужно использовать специальные функции, которые можно разделить на 4 направления:
Lowest Rated Post — статьи с наименьшим рейтингом. Highest Rated Post — статьи с наибольшим рейтингом. Most Rated Post — публикации за которые больше всего раз голосовали. Highest Score Post — пост с максимальным средним показателем рейтинга, то есть, например, заметка с двумя голосами в сумме дающим 6.5 будет выше чем пост с одной оценкой в 7 баллов.На официальном сайте плагина есть синтаксис для всех этих случаев и некоторые другие особенности. Смысла перепечатывать все, что там сказано, я не вижу, можно всегда глянуть в первоисточник. Единственное, что покажу парочку примеров.
Примеры использования плагина WP-PostRatings
Статьи с наименьшим рейтингом
<?php if ( function_exists ( 'get_lowest_rated' ) ) : ?> <ul> <?php get_lowest_rated ( ) ; ?> </ul> <?php endif ; ?> |
<?php if (function_exists('get_lowest_rated')): ?> <ul> <?php get_lowest_rated(); ?> </ul> <?php endif; ?>
где по умолчанию для функции используются параметры get_lowest_rated(‘both’, 0, 10). Здесь вместо both можно использовать отдельно post и page, то есть выводить оценки постов, страниц отдельно или вместе. Значение 0 — минимальная оценка для отображения в списке, 10 — количество выводимых постов.
Пост с самым большим рейтингом по тегу
<?php if ( function_exists ( 'get_highest_rated_tag' ) ) : ?> <ul> <?php get_highest_rated_tag (TAG_ID ) ; ?> </ul> <?php endif ; ?> |
<?php if (function_exists('get_highest_rated_tag')): ?> <ul> <?php get_highest_rated_tag(TAG_ID); ?> </ul> <?php endif; ?>
По умолчанию параметры функции следующие get_highest_rated_tag(TAG_ID, ‘both’, 0, 10). Здесь последние значения идентичны предыдущему примеру, а вот в качестве TAG_ID нужно указать ID тега, для которого выводится список рейтинговых постов. Если хотите использовать несколько тегов, то вместо одного значения добавляете массив array(1, 2 , 3 ) .
Самый оцениваемая запись в категории
<?php if ( function_exists ( 'get_most_rated_category' ) ) : ?> <ul> <?php get_most_rated_category (CATEGORY_ID ) ; ?> </ul> <?php endif ; ?> |
<?php if (function_exists('get_most_rated_category')): ?> <ul> <?php get_most_rated_category(CATEGORY_ID); ?> </ul> <?php endif; ?>
По умолчанию синтаксис функции get_most_rated_category(CATEGORY_ID, ‘both’, 0, 10). Здесь для CATEGORY_ID указывает номер категории, можно использовать массив array( 4 , 5, 6 ) . Для постов вместо ‘both’ ставим ‘post’, 0 — минимальное количество голосов для отображения, 10 — число выводимых записей.
Список лучших публикаций по средней оценке за период
<?php if ( function_exists ( 'get_highest_score_range' ) ) : ?> <ul> <?php get_highest_score_range ( '1 day' ) ; ?> </ul> <?php endif ; ?> |
<?php if (function_exists('get_highest_score_range')): ?> <ul> <?php get_highest_score_range('1 day'); ?> </ul> <?php endif; ?>
По умолчанию функция имеет вид — get_highest_score_range(‘1 day’, ‘both’, 10). Как видимо, количество дней для периода нужно указывать обязательно. При этом можно использовать значения по типу ‘ 2 days ‘ , ‘ 1 month ‘ . 10 — число записей, ‘both’ — их формат (посты + страницы).
Отображение рейтинга без голосования
Если вам нужно просто вывести результат рейтинга постов без функции голосования, то следует использовать следующую конструкцию:
<?php if ( function_exists ( 'the_ratings' ) ) { echo expand_ratings_template ( '<span class="rating">%RATINGS_IMAGES%</span> <strong>%RATINGS_USERS% votes</strong>' , get_the_ID ( ) ) ; } ?> |
<?php if(function_exists('the_ratings')) { echo expand_ratings_template('<span class="rating">%RATINGS_IMAGES%</span> <strong>%RATINGS_USERS% votes</strong>', get_the_ID()); } ?>
Здесь переменная RATINGS_IMAGES отвечает за вывод графики («звездочек»), а вместо RATINGS_USERS подставляется значению рейтинга. Размещаете функцию в файле шаблона, где хотите показывать результаты, точно также как рассказывалось про отображение кода выше (т.е. внутри цикла if have_posts). Кстати, в админке в разделе настроек модуля на странице Post Ratings Templates найдете список всех возможных переменных.
В целом ничего сложно нет, но кое какие хаки и мысли по модификации плагина я уже успел воплотить в жизнь как здесь, так и на Дизайн Мании. Подробный разбор исходников и некоторых функций плагина WP-PostRatings смотрите в следующей заметке — но там информация больше для продвинутых пользователей, начинающим и вообще в 90% случаев достаточно этой статьи и описания на официальном сайте.
Рейтинг с помощью кнопки Лайк
В качестве альтернативы, если вам требуется организовать рейтинг с помощью кнопки Лайк, можете воспользоваться плагином Like Button Rating . Плагин предоставляет мгновенную статистику, 28 готовых тем, 140 иконок и позволяет сортировать материалы по лайкам. Работает с постами, страницами, товарами WooCommerce, BuddyPress, bbPress и комментариями.
P.S. Постовой. Новый полезные сайт для работников Forex рынка, где найдете рейтинг форекс брокеров а также много другой ценной информации по теме.