制作用户评星

方法一:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<div>
<img id="1" class="" src="empty.png" alt="">
<img id="2" class="" src="empty.png" alt="">
<img id="3" class="" src="empty.png" alt="">
<img id="4" class="" src="empty.png" alt="">
<img id="5" class="" src="empty.png" alt="">
<span></span>
</div>
<script src="jquery-1.12.2.min.js"></script>
<script>
$("span").css({"color":"red","font-size":"16px"});
this.$("img").click(function(){
$(this).attr({"src":"shining.png","class":"2"});
$(this).prevAll().attr({"src":"shining.png","class":"2"});
$(this).nextAll().attr("src","empty.png");
if($(this).attr("id")==1){
$("span").html("很差");
}
if($(this).attr("id")==2){
$("span").html("较差");
}
if($(this).attr("id")==3){
$("span").html("一般");
}
if($(this).attr("id")==4){
$("span").html("较好");
}
if($(this).attr("id")==5){
$("span").html("很好");
}
})
this.$("img").hover(function(){
$(this).attr({"src":"shining.png","class":"1"});
$(this).prevAll().attr({"src":"shining.png","class":"1"});
$(this).nextAll().attr("src","empty.png");
if($(this).attr("id")==1){
$("span").html("很差");
}
if($(this).attr("id")==2){
$("span").html("较差");
}
if($(this).attr("id")==3){
$("span").html("一般");
}
if($(this).attr("id")==4){
$("span").html("较好");
}
if($(this).attr("id")==5){
$("span").html("很好");
}
},function(){
if($(this).attr("class")==1){
$(this).attr("src","empty.png");
$(this).prevAll().attr("src","empty.png");
$(this).nextAll().attr("src","empty.png");
$("span").html("");
}else{
$(this).attr("src","shining.png");
$(this).prevAll().attr("src","shining.png");
$(this).nextAll().attr("src","empty.png");
}
})
</script>
</body>
</html>

方法二:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.container{
float:left;
}
.score{
float: left;
position: relative;
width: 100px;
margin-top: 5px;
margin-left: 10px;
}
span{
display: none;
position: absolute;
font-family: "Microsoft YaHei";
left: 0;
top: 0;
}
.scoreDisplay{
display: block;
}
</style>
<script src="jquery-1.11.1.js"></script>
</head>
<body>
<!-- 一个容器里面放5张图片,先所有的都空星图片-->
<!-- 该案例的要点就是在于鼠标移动上去时改变图片的src-->
<div class="container">
<img src="empty.png" alt="">
<img src="empty.png" alt="">
<img src="empty.png" alt="">
<img src="empty.png" alt="">
<img src="empty.png" alt="">
</div>
<div class="score">
<span>很差</span>
<span>较差</span>
<span>一般</span>
<span>较好</span>
<span>很好</span>
</div>
<script>
var img = $(".container img");//获取5张图片的集合
var span = $(".score span");
var i,j,k;//定义变量i,j,k
k = -1;//k给予一个初始值-1,,不然后面第1个星星始终是被点亮的
img.mouseenter(function(){ //设置鼠标进入时的效果,首先将所有的星星熄灭,然后再根据用户鼠标进入的星星下标值点亮星星
span.removeClass("scoreDisplay");//鼠标进入时,将右边的评论清除掉
img.attr("src","empty.png");
i = img.index(this);
for(j=0;j<=i;j++)
{
img.eq(j).attr("src","shining.png");
}
span.eq(i).addClass("scoreDisplay");//根据用户进入的i值来显示评论
}).mouseleave(function(){ //仍然是将所有的星星熄灭,然后根据k值来点亮星星
span.removeClass("scoreDisplay");//鼠标离开时,首先清除掉评论
img.attr("src","empty.png");//接下来将所有星星变为空星
for(j=0;j<=k;j++)//根据最终值k值来确定点亮几颗星星
{
img.eq(j).attr("src","shining.png");
}
if(k==-1)//如果k值=-1,则不显示任何一个评论内容
{
span.removeClass("scoreDisplay");
}
else{
span.eq(k).addClass("scoreDisplay");//根据最终值k值显示评论
}
})
$("img").click(function(){ //k记录用户点击鼠标时的星星下标值
k = img.index(this);
})
</script>
</body>
</html>

posted @ 2017-03-27 13:02  南城故人陌  阅读(128)  评论(0编辑  收藏  举报