博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
星级评分--jQuery插件
阅读量:6296 次
发布时间:2019-06-22

本文共 2317 字,大约阅读时间需要 7 分钟。

以前写过一篇文章 ,今天有时间把这个功能重写,并以jQuery插件的形式出现以便以后使用。 首先看一下运行效果如下图所示。

    鼠标移到星星上该星星前面的所有星星全部变亮,鼠标单击将记录点击的星星数,前面的所有星星将变亮。

    一、原理

    本程序的原理是这样的:一个“ul”标签,该标签的背景为灰色的星星,控制“ul”标签的宽度显示星星的数量。例如:一个星星图片的宽度为23px,那么要显示10个星星,则“ul”的宽度为230px就可以显示10个星星。

    n个“li”标签,n表示您要显示星星的个数,例如你要显示10个星星那么将有10个“li”标签。那么这10个标签的宽度分别为1个星星的宽度23px,2个星星的宽度46px,......,10个星星的宽度230px。这些“li”标签的背景将为蓝色的星星。

   则另外还有一个“li”标签记录鼠标单击的星星或初始设置。

   这些标签都是重叠在一起的,通过鼠标滑动效果切换这些标签的层叠顺序,显示不同的星星数量,单击记录星星个数。

   二、源码

   $.fn.studyplay_star=function(options,callback){

 //默认设置
 var settings ={
  MaxStar      :20,
  StarWidth    :23,
  CurrentStar  :5,
  Enabled      :true
  }; 
 if(options) { jQuery.extend(settings, options); };
 var container = jQuery(this);
 container.css({"position":"relative"})
 .html('<ul class="studyplay_starBg"></ul>') 
 .find('.studyplay_starBg').width(settings.MaxStar*settings.StarWidth)
 .html('<li class="studyplay_starovering" style="width:'+settings.CurrentStar*settings.StarWidth+'px; z-index:0;" id="studyplay_current"></li>');
 if(settings.Enabled)
 {
 var ListArray = ""; 
 for(k=1;k<settings.MaxStar+1;k++)
 {
  ListArray +='<li class="studyplay_starON" style="width:'+settings.StarWidth*k+'px;z-index:'+(settings.MaxStar-k+1)+';"></li>';
 }
 container.find('.studyplay_starBg').append(ListArray)
 .find('.studyplay_starON').hover(function(){
             $("#studyplay_current").hide();
             $(this).removeClass('studyplay_starON').addClass("studyplay_starovering");
             },
           function(){
            $(this).removeClass('studyplay_starovering').addClass("studyplay_starON");
            $("#studyplay_current").show();
            })
 .click(function(){
     var studyplay_count = settings.MaxStar - $(this).css("z-index")+1;
     $("#studyplay_current").width(studyplay_count*settings.StarWidth)
     //回调函数
     if (typeof callback == 'function') {
     callback(studyplay_count);
     return ;
     }
     })
 } 
}

  这个插件有两个参数一个是options表示插件的一些基本设置;callback表示回调函数,该函数存在一个参数表示用户选择的星星数量。

   三、使用

  如果我们想在id为“z”的div上显示5个星星,默认有一颗星星选中,弹出选择星星的个数对话框,就可以如下编写代码:

<div id="z"></div>

<script type="text/javascript">

  $(document).ready(function(){
   $("#z").studyplay_star({MaxStar:5,CurrentStar:2},function(value){alert(value)});
  }); 
</script>

如果想显示评分结果 可以把Enabled设置false就ok了

 四、代码下载

经网友反映说火狐下面存在这问题,今天进行了调试进行了修改 主要是因为样式中li标签没有定义高度引起的,现在已经修正,谢谢朋友们。火狐修正版下载地址:

 

真心的谢谢网友们

第三次修改:添加0.5分评分功能

使用说明:其中half等于0表示一分一分的增加,1表示0.5的增加

例如:$("#z").studyplay_star({MaxStar:12,CurrentStar:2,Enabled:true,Half:1},function(value){alert(value)});

下载地址:

转载地址:http://fkmta.baihongyu.com/

你可能感兴趣的文章
树形dp poj2342 Anniversary party * 求最大价值
查看>>
定义变量时无引号,单引号,双引号区别与特点:
查看>>
Search in Rotated Sorted Array(二分查找)
查看>>
angular代码分析之异常日志设计
查看>>
C语言笔试
查看>>
css样式使用实例
查看>>
Linux fstab参数详解
查看>>
9、动态规划
查看>>
怎样实现前端裁剪上传图片功能
查看>>
小白们应当知道的配置系统变量PATH 的小技巧。
查看>>
Oracle删除指定用户下所有对象
查看>>
实现自己的连接池(一)
查看>>
grunt入门讲解1:grunt的基本概念和使用
查看>>
8.10 exec函数
查看>>
谈谈js初级封装代码
查看>>
LeetCode 76. Minimum Window Substring
查看>>
Hive中数据的加载和导出
查看>>
CSS3秘笈第三版涵盖HTML5学习笔记13~17章
查看>>
国际马的跳法
查看>>
资深程序员不一定当得了软件架构师
查看>>