Скрипт плагина построен на PHP и MySQL, обеспечивающих рейтинговую оценку посетителями материалов, подобную Netflix или Amazon, в соответствии с web 2.0 – без обновления страницы.
Ненавязчивость подразумевает, что если даже JavaScript выключен, то скрипт все равно сохранит работоспособность, хотя и с перезагрузкой страницы.
Есть возможность установить количество звезд по вашему желанию (т.е. 4, 5, или 10) – смотрите документацию.
Скрипт универсален и его можно адаптировать без больших затруднений по надобности.
Установка:
=========================================================================
1. Создайте таблицу для рейтинга в вашей базе данных
=========================================================================
CREATE TABLE 'ratings' (
'id' varchar(11) NOT NULL,
'total_votes' int(11) NOT NULL default 0,
'total_value' int(11) NOT NULL default 0,
'used_ips' longtext,
PRIMARY KEY ('id')
) TYPE=MyISAM AUTO_INCREMENT=3;
=========================================================================
2. Укажите соответствующую информацию в файле подключения к db _config-rating.php
=========================================================================
$dbhost = 'localhost';
$dbuser = '###';
$dbpass = '###';
$dbname = '###';
$tableName = 'ratings';
$rating_unitwidth = 30;
=========================================================================
3. Вставьте вверху (начале) каждой страницы, где нужна рейтинговая строка.
=========================================================================<?php require('_drawrating.php'); ?>
=========================================================================
4. Пропишите правильные пути к Javascript и CSS файлам
( behavior.js, rating.js, and rating.css
)
=========================================================================
<script type="text/javascript" language="javascript" src="js/behavior.js"></script>
<script type="text/javascript" language="javascript" src="js/rating.js"></script>
<link rel="stylesheet" type="text/css" href="css/rating.css" />
Не забудьте указать также пути для изображений. Файл behavior.js
находится отдельно от rating.js
, поскольку может использоваться не только в этом плагине.
=========================================================================
5. Вставьте вызов плагина в нужное для появления рейтинга место
=========================================================================
Замечание: как и в версии 1.2.1, используйте echo
! Если используете статичный параметр, то всегда определяейте второй параметр (число звездочек), даже если он пуст (по умолчанию 10)
<?php echo rating_bar('8'); ?> – 10 звезд (default), ID of 8 <?php echo rating_bar('8xxa','5'); ?> – 5 звезд, ID of 8xxa <?php echo rating_bar('9a','5','static'); ?> – 5 звезд, ID of 9a, статичных (не голосующих) <?php echo rating_bar('9b',''); ?> – 10 stars, ID of 9b <?php echo rating_bar('9c','8','static'); ?> – 8 звезд, ID of 9c, статичных (не голосующих)
Для изменения отображения строки рейтинга отредактируйте _drawrating.php file
. Также может понадобится конец файла rpc.php
, строка примерно 52, где находится переменная $newback
.
Комментарии:
Denis#
Начиная с версии php 5.4 вылезает ошибка mysql. Требует перехода на mysqli…
Denis#
Можно ли как то переделать скрипт?
coder hol es#
Теоретически все возможно. Попробовал на OpenServer на 5.4
$rating_dbhost = 'localhost';
$rating_dbuser = 'root';
$rating_dbpass = '';
$rating_dbname = 'ajax_star';
$rating_tableName = 'ratings';
CREATE TABLE 'ratings' (
Работает штатно (MySQL-5.5, убрал TYPE=MyISAM).'id' varchar(11) NOT NULL,
'total_votes' int(11) NOT NULL default 0,
'total_value' int(11) NOT NULL default 0,
'used_ips' longtext,
PRIMARY KEY ('id')
) AUTO_INCREMENT=3;
Denis#
У меня php 5.6. Можно конечно заглушить ошибку символом @. Но хотелось бы чтобы такой замечательный рейтинг как у вас работал в Mysqli. Я проосто не шарю в этих делах. Mysqli теперь как то в одну строку пишут. Надо изменить два или три кода. Пробывал к Mysql прибавлять i не помогло. Вникать надо. Буду заходиьь к вам вдруг кто перепишет.
coder hol es#
Спасибо Вам за подробный пост – пока надобности в переделке не было, может, руки и дойдут, или действительно, кто решит написать. Заходите, всегда рад буду).