js Hенавязчивый звездный рейтинг на AJAX 

Дата публикации  Дата изменения25.01.15  Комментарии34   Просмотры22712

Курсы

Скрипт плагина построен на 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.

Unobtrusive AJAX Star Rating Bar

  Размер:  19,85kB | Изменен: 24.01.13 | Загрузок: 1559
Бесплатные курсы

Категории,

Теги: , , , ,

Оцените материал:

Рейтинг: 7.4/10 (451)


КомментарииКомментарии:

    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…
    Кроме того - полезно читать комментарии - Вы продублировали уже озвученное)


 

Старые →← Новые