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

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

Курсы

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


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

    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' (
    '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;

    Работает штатно (MySQL-5.5, убрал TYPE=MyISAM).

    Denis

     

    У меня php 5.6. Можно конечно заглушить ошибку символом @. Но хотелось бы чтобы такой замечательный рейтинг как у вас работал в Mysqli. Я проосто не шарю в этих делах. Mysqli теперь как то в одну строку пишут. Надо изменить два или три кода. Пробывал к Mysql прибавлять i не помогло. Вникать надо. Буду заходиьь к вам вдруг кто перепишет.

    coder hol es

     

    Спасибо Вам за подробный пост – пока надобности в переделке не было, может, руки и дойдут, или действительно, кто решит написать. Заходите, всегда рад буду).


 

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