Я использую этот шаблон для отображения рейтинга рядом с пользователем.
{insert name=get_percent value=a assign=mpercent userid=$p.USERID}
{if $mpercent ne ""}
<div class='user-rate'>
rate<span class='green'>{$mpercent}%</span>
</div>
{else}
<div class='user-rate'>not rated yet</div>
{/if}
Я хотел бы изменить рейтинг с процентного значения на звездный рейтинг (0-5).
Я попробовал ответ в этой ссылке
это код, когда я добавил следующий CSS:
span.stars, span.stars span {
display: block;
background:url(../images/stars.png) 0 -16px repeat-x;
width: 80px;
height: 16px;
}
span.stars span {
background-position: 0 0;
}
И JavaScript:
$(function() {
$("span.stars").stars();
});
$.fn.stars = function() {
return $(this).each(function() {
$(this).html($('<span />')
.width(Math.max(0, (Math.min(5, parseFloat($(this).html())))) * 16));
});
}
И использовали это для каждого из рейтингов:
<p> <span class="stars">{$mpercent}</span> </p>
я использовал {$mpercent}
, чтобы получить рейтинг участника, но в результате я постоянно получаю 5 звезд.
Если я изменю значение класса span на фиксированное число (скажем, 1,2 или 3), я также получу тот же результат.