欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jquery实现类似淘宝星星评分功能有截图

程序员文章站 2023-01-21 23:30:36
html

  • &l...

html

<body>
<p id="p">
<ul>
<li>☆</li>
<li>☆</li>
<li>☆</li>
<li>☆</li>
<li>☆</li>
</ul>
</p>
<p id="p"></p>
<p id="score"></p>
</body>

id="p"显示即时分数

id="score"显示最终分数----------------------------------------------

javascript“

$(function () {

//为所有的li标签绑定mouseout和mouseover事件。bind({事件名:function(){},事件名:function(){}})的方法绑定多个事件
$("#p li").bind({
mouseout:function () {
$(this).css("color", "black").html("☆").prevall().css("color", "black").html("☆")
},
mouseover: function () {
$(this).css("color", "red").html("★").prevall().css("color", "red").html("★")
}
});
//=实时显示分数.【index】搜索匹配的元素,并返回相应元素的索引值,从0开始计数。
$("#p li").mouseover(function () {
$("#p").html(parseint( $(this).index("#p li"))+1);
});
//鼠标按下时,确定分数。额,就不更改了,大局已定。
$("#p li").mousedown(function () {
$("#score").html(("你选择的分数是" + (parseint($(this).index("#p li")) + 1)));
$(this).css("color", "red").html("★").prevall().css("color", "red").html("★")
//全部li标签的绑定事件全部清除--unbind方法可以加参数清除特定的事件。不加全部清除
$(this).unbind().prevall().unbind().nextall().unbind();
});
})

出现的效果是这样的:

jquery实现类似淘宝星星评分功能有截图

可惜的是你一点击下去--就不可更改了。真的是很悲伤啊。大概也只是做了一个小样子而已。

prevall() 和nextall()这两个方法?暂且说方法吧。在jquery的文档可以查得到。

index 在jquery 里是返回元素的索引值,从零开始。分数呢就加1,