javascript星级评分(多个)

JS打多个类型星级评分:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
    <meta charset="UTF-8">
    <title>javascript星级评分</title>
    <script src="Scripts/jquery-1.7.2.min.js" type="text/javascript"></script>
    <style type="text/css">
        *
        {
            margin: 0;
            padding: 0;
        }
        .wrapper
        {
            height: 20px;
            padding: 5px;
            width: 130px;
            margin: 100px auto 10px;
        }
        .wra
        {
            height: 20px;
            padding: 5px;
            width: 130px;
            margin: 100px auto 10px;
        }
        a
        {
            float: left;
            width: 26px;
            height: 20px;
            background: url(img/star.png) 0 -20px no-repeat;
        }
        p
        {
            font: 24px SimSun;
            width: 130px;
            margin-left: auto;
            margin-right: auto;
        }
    </style>
</head>
<body>
    <div id="a1" class="wrapper">
        <a href="javascript:;"></a><a href="javascript:;"></a><a href="javascript:;"></a>
        <a href="javascript:;"></a><a href="javascript:;"></a>
    </div>
    <p id="p1">
    </p>
    <div id="a2" class="wrapper">
        <a href="javascript:;"></a><a href="javascript:;"></a><a href="javascript:;"></a>
        <a href="javascript:;"></a><a href="javascript:;"></a>
    </div>
    <p id="p2">
    </p>
    <div id="a3" class="wrapper">
        <a href="javascript:;"></a><a href="javascript:;"></a><a href="javascript:;"></a>
        <a href="javascript:;"></a><a href="javascript:;"></a>
    </div>
    <p id="p3">
    </p>
    <div id="a4" class="wrapper">
        <a href="javascript:;"></a><a href="javascript:;"></a><a href="javascript:;"></a>
        <a href="javascript:;"></a><a href="javascript:;"></a>
    </div>
    <p id="p4">
    </p>
</body>
</html>
<script type="text/javascript">
    $(function () {
        var objs = $(".wrapper a");
        $(objs).mouseover(function () {
            var ix = $(this).index();
            sets(ix, this);
        });

        $(objs).mouseout(function () {
            var ix = $(this).parent().attr("rel");
            if (ix == undefined)
                ix = -1;
            sets(ix, this);
        });

        $(objs).click(function () {
            var ix = $(this).index();
            $(this).parent().next("p").html((ix + 1) + ‘ 颗星‘);
            $(this).parent().attr("rel", ix);
            sets(ix, this);
        });
    });
    function sets(ix, obj) {
        $(obj).parent().children().each(function (ik) {
            if (ik <= ix) {
                $(this).css("backgroundPosition", ‘0 0‘);
            } else {
                $(this).css("backgroundPosition", ‘0 -20px‘);
            }
        });
    }
</script>

单个星级评分(纯JS):

<script type="text/javascript">
    window.onload = function () {
            var star = document.getElementById(‘a1‘).getElementsByTagName(‘a‘);

            var temp = 0;

            for (var i = 0, len = star.length; i < len; i++) {
                star[i].index = i;

                star[i].onmouseover = function () {
                    clear();
                    for (var j = 0; j < this.index + 1; j++) {
                        star[j].style.backgroundPosition = ‘0 0‘;
                    }
                }

                star[i].onmouseout = function () {
                    for (var j = 0; j < this.index + 1; j++) {
                        star[j].style.backgroundPosition = ‘0 -20px‘;
                    }
                    current(temp);
                }

                star[i].onclick = function () {
                    temp = this.index + 1;
                    document.getElementById(‘p1‘).innerHTML = temp + ‘ 颗星‘;
                    current(temp);
                }
        }
        //清除所有
        function clear() {
            for (var i = 0, len = star.length; i < len; i++) {
                star[i].style.backgroundPosition = ‘0 -20px‘;
            }
        }
        //显示当前第几颗星
        function current(temp) {
            for (var i = 0; i < temp; i++) {
                star[i].style.backgroundPosition = ‘0 0‘;
            }
        }
    };
</script>
时间: 2024-11-08 03:45:29

javascript星级评分(多个)的相关文章

js实现星级评分之方法一

利用一个星级评分的小案例,来逐步封装js星级评分插件. 从最基础的js知识,通过一个小的demo,逐步学习js的面向对象知识. 从浅到深,逐步递进. 图片素材 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>星级评分--第一种实现方式</title> </head> <style type="text/css&quo

数组练习:各种数组方法的使用&amp;&amp;事件练习:封装兼容性添加、删除事件的函数&amp;&amp;星级评分系统

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

ExtJS(3)- 自定义组件(星级评分)

今天介绍ExtJS的组件开发,这里以星级评分为示例,首先来看看效果图: 然后是功能操作:鼠标移动到五个星星上面时,会有tooltip显示当前的分值.如图:鼠标悬停在第四颗星星时前四颗星星显示高亮笑脸,当点击下去时锁定笑脸并且设定份数为4. 然后我们来说一下实现原理,Ext的组件基本单元是Ext.Component,所以自定义组件可以继承Component,然后显示部分直接用html来显示,包括css和动态事件都可以直接在html上编辑添加. 接下来我们来看代码: Ext.define('Pact

jQuery Raty - 不错的星级评分插件

在做商品评价时,一般情况下,我们需要一个星级评分的组件,而jQuery Raty恰好满足我们的需求. 一.展示 二.使用教程 ①.下载插件 https://github.com/wbotelhos/raty ②.导入文件 <script type="text/javascript" src="${ctx}/components/raty/jquery.raty.js"></script> <link type="text/cs

js实现星级评分效果(最短代码)

1. 前言 此方案受到JS单行写一个评级组件启发,自己写了一个简单Demo. 功能有正常滑动,动态显示实心星星个数:当点击确认,则保持当前的实心星星个数:再移动时为点击,则离开后还是保持之前的状态. 此demo没有文字信息等提示,可以根据需要自行添加使用. 2. 代码 <!DOCTYPE html> <html> <head> <title>Star Rating</title> <script src="http://apps.

js星级评分点击星级评论打分效果--收藏--转载

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

js css 星级评分

利用css 和 js 实现星级评分 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>rating</title> </head> <style > *{margin:0;padding: 0} ul{width:500px; padding:100px;padding:0 auto

慕课网 星级评分原理和实现(上)

源码下载 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>星级评分--第一种实现方式</title> <style> body, ul, li { padding: 0; margin: 0; display: block; } li { list-style-type: none; } .r

慕课网上的星级评分--学习视频后模仿实现

1.本人观看了慕课网上的星级评分视频,课程免费,老师讲的特别棒!视频链接:https://www.imooc.com/learn/842 2.在学习完视频后找到了一位大神手敲的代码,在他的Github上下载后,自己手动实现了一遍.源代码稍后贴出原作者的给的链接:http://www.cnblogs.com/fazero/p/8316926.html 3.本人手动模仿实现了一遍代码,学习了好多,再次只贴出最终的可以点亮整颗星与半颗星的javascript代码,如有雷同版权为原作者所有: <scri