jQuery动态五星评分

简介:

效果

css

.star ul,
.star li {
    list-style: none;
}

.star {
    position: relative;
    width: 600px;
    height: 24px;
    margin: 20px auto 0;
}

.star span {
    float: left;
    height: 19px;
    line-height: 19px;
}

.star ul {
    margin: 0 10px;
}

.star li {
    float: left;
    width: 24px;
    height: 22px;
    text-indent: -9999px;
    background: url('../img/star.png') no-repeat;
    cursor: pointer;
}

.star li.on {
    background-position: 0 -28px;
}

.star p {
    padding: 10px 10px 0;
    position: absolute;
    top: 20px;
    width: 159px;
    height: 60px;
    z-index: 100;
}

.star p em {
    color: #FF6600;
    display: block;
    font-style: normal;
}

.star strong {
    color: #ff6600;
    padding-left: 10px;
}

.hidden {
    display: none;
}

html

<!DOCTYPE HTML>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
    <title>jQuery实现五星级评分</title>
    <link rel="stylesheet" href="./css/score.css">
    <script type="text/javascript" src="./js/jquery-1.10.2.min.js"></script>
    <script type="text/javascript" src="./js/score.js"></script>
    
</head>
<body>
    <div class="star" id="goods">
        <span>商品</span>
        <input type="hidden" class="value-container" name="goods" value="">
        <ul>
            <li><a href="javascript:;">1</a></li>
            <li><a href="javascript:;">2</a></li>
            <li><a href="javascript:;">3</a></li>
            <li><a href="javascript:;">4</a></li>
            <li><a href="javascript:;">5</a></li>
        </ul>
    </div>

    <div class="star" id="logistics">
        <span>物流</span>
        <input type="hidden" class="value-container" name="logistics" value="">
        <ul>
            <li><a href="javascript:;">1</a></li>
            <li><a href="javascript:;">2</a></li>
            <li><a href="javascript:;">3</a></li>
            <li><a href="javascript:;">4</a></li>
            <li><a href="javascript:;">5</a></li>
        </ul>
    </div>
    <script type="text/javascript">
    $(function() {
        var goods_score = new Score({selector:'#goods.star'});
        var logistics_score = new Score({selector:'#logistics.star'});
    });
    </script>
</body>
</html>

js

function Score(options) { // 定义一个类
    this.config = {
        selector: '.star', // 评分容器
        renderCallback: null, // 渲染页面后回调
        callback: null // 点击评分回调                         
    };

    this.cache = {
        iStar: 0,
        iScore: 0
    };

    this.init(options); // 构造函数
}

Score.prototype = {
    constructor: Score,
    init: function(options) {
        this.config = $.extend(this.config, options || {});
        var self = this,
            _config = self.config,
            _cache = self.cache;

        self._renderHTML();
    },
    _renderHTML: function() {
        var self = this,
            _config = self.config;
        var html = '<span class="desc"></span>' +
            '<p class="star-p hidden"></p>';
        $(_config.selector).each(function(index, item) {
            $(item).append(html);
            $(item).wrap($('<div class="parentCls" style="position:relative"></div>'));
            var parentCls = $(item).closest('.parentCls');
            self._bindEnv(parentCls); // 方法层层相扣
            _config.renderCallback && $.isFunction(_config.renderCallback) && _config.renderCallback();
        });

    },
    _bindEnv: function(parentCls) {
        var self = this,
            _config = self.config,
            _cache = self.cache;

        $(_config.selector + ' li', parentCls).each(function(index, item) {

            // 鼠标移上
            $(item).mouseover(function(e) {
                var offsetLeft = $('ul', parentCls)[0].offsetLeft;
                ismax(index + 1);

                $('p', parentCls).hasClass('hidden') && $('p', parentCls).removeClass('hidden');
                $('p', parentCls).css({
                    'left': index * $(this).width() + 12 + 'px'
                });
            });

            // 鼠标移出
            $(item).mouseout(function() {
                ismax();
                !$('p', parentCls).hasClass('hidden') && $('p', parentCls).addClass('hidden');
            });

            // 鼠标点击
            $(item).click(function(e) {
                var index = $(_config.selector + ' li', parentCls).index($(this));
                _cache.iStar = index + 1;

                var score = index + 1;

                !$('p', parentCls).hasClass('hidden') && $('p', parentCls).addClass('hidden');
                var html = '<strong>' +
                    score +
                    '分</strong>';

                $('.desc', parentCls).html(html);

                // 加入分数
                $(this).parents(_config.selector).find('.value-container').val(score);
                // $(_config.selector).find('.value-container').val(score);

                _config.callback && $.isFunction(_config.callback) && _config.callback({
                    starAmount: _cache.iStar
                }); // 回调函数
            });

        });

        function ismax(iArg) {
            _cache.iScore = iArg || _cache.iStar;
            var lis = $(_config.selector + ' li', parentCls);

            for (var i = 0; i < lis.length; i++) {
                lis[i].className = i < _cache.iScore ? "on" : "";
            }
        }
    }
};

这里有两种方式
1.针对所有的.star的
2.针对具体的.star的

$(function() {
        //var score = new Score(); // 不传参数,默认是.star
        var goods_score = new Score({selector:'#goods.star'}); // 传参数,只针对id为goods的.star
        var logistics_score = new Score({selector:'#logistics.star'});
});

本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/5368258.html,如需转载请自行联系原作者
相关文章
|
JavaScript
jQuery 五角星评分案例(详细代码)
jQuery 五角星评分案例(详细代码)
120 0
|
2月前
|
JavaScript
jQuery实现的星级打分带评价及颜色区分代码
jQuery实现的星级打分带评价及颜色区分效果代码是一款支持自定义评论颜色的星级评价打分,其中红色为一星级,差评、绿色位五星级、满分好评,本段代码适应于所有网页使用,有需要的朋友们就来下载使用吧。
32 2
|
8月前
|
JavaScript 前端开发
jquery实现动态五角星评分
jquery实现动态五角星评分
|
JSON JavaScript 前端开发
jQuery ——(很全、很清晰,三小时带你学会 jQuery 基础)
jQuery ——(很全、很清晰,三小时带你学会 jQuery 基础)
364 0
|
JavaScript
js实现星星评分功能的实现(逻辑思路)
js实现星星评分功能的实现(逻辑思路)
118 0
|
JavaScript
Jquery 效果综合案例效果
Jquery 效果综合案例效果
128 0
Jquery 效果综合案例效果
|
JavaScript 前端开发
某东网页(动态)搭建(jquery)
网页编程实战三: 利用jquery实现京东网页(动态)搭建,
某东网页(动态)搭建(jquery)
|
Web App开发 JavaScript 前端开发
换一种方式来实现CSS评分组件
换一种方式来实现CSS评分组件
换一种方式来实现CSS评分组件
|
JavaScript 前端开发
jQuery Raty - 不错的星级评分插件
jQuery Raty - 不错的星级评分插件
317 0
jQuery Raty - 不错的星级评分插件
|
Web App开发
【赏析】15个非常棒的使用CSS3的设计组合
尽管在浏览器的支持上还有一定不足,特别是IE浏览器,但不可否认,HTML5 + CSS3将会是下一代Web开发技术的主流,本文向你介绍15个设计非常棒的经典CSS3的网站,他们都有共同的特点:排版新颖、页面简洁吸引人。
782 0

相关课程

更多