Скрипт плагина построен на 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
.
Комментарии:
Vladimir#
После попытки создать таблицу через Sql запрос выходит ошибка ошибка Статический анализ: В ходе анализа было обнаружено 4 ошибки. Ожидалось имя символа! (около «id» в позиции 27) Ожидалось хотя бы одно определение столбцов. (около «id» в позиции 27) Неожиданное начало заявления. (около «11» в позиции 40) Нераспознанный тип оператора. (около «NOT NULL» в позиции 44) SQL-запрос: CREATETABLE 'ratings' ('id' varchar (11) NOTNULL, 'total_votes' int (11) NOTNULL default 0, 'total_value' int (11) NOTNULL default 0, longtext, used_ips, PRIMARYKEY ('id ')) TYPE = MyISAM AUTO_INCREMENT = 3 MySQL сказал: Документация #1064 – You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near ''ratings' ( 'id' varchar(11) NOTNULL, 'total_votes' int(11) NOTNULL defaul' at line 1
coder hol es#
Vladimir – статья 13 года. Возможно, что-то у Вас уже совсем другое и не соответствует изложенному.
Леонид#
Много чего с базами делал но такое выдает впервые от вашего примера. #1064 – You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''ratings' ( 'id' varchar(11) NOTNULL, 'total_votes' int(11) NOTNULL default ' at line 1 и ничего не создает Я не программист.
coder hol es#
Любой пример нужно адаптировать к своим нуждам – особенно, когда дата материала давнишняя.
Многое с того времени изменилось) – и версии php у многих, и версии mysql…
Кроме того - полезно читать комментарии - Вы продублировали уже озвученное)