问题讨论:程序 C/C++ Java GUI编程 ASP Php Shell Perl Web开发 软件工程 三大件 机箱 存储设备 光存储 音频设备 视频设备 外设 购机
asp php java C CGI .net vb delphi unix|linux sql Word Excel WPS OutLook Powerpoint Dreamweaver FPage/Golive CSS/HTML DOM/JS
热门词:流程图 excel 入侵检测 vss Windows 安全漏洞 QQ空间 事件编程 MFC

 程序设计交流 > Web开发 

js实现星星打分效果 实现星星打分效果

[2011-11-14 15:04:23] [来源: 百家电脑学院] [我要投稿]

js实现星星打分效果






javascript+css好多网站用的选星星实现打分功能的函数
函数有两个参数,功能如下:
obj: img标签组的父容器,类型为DOM对象;
oEvent: event对象。
这个函数的优点是html代码可以很简洁,使用图片也可以很少,只需要两张图片。事件句柄只需要写在img的父容器上即可。演示用的图片我用的是绝对地址,各位在使用的时候改成网站的相对地址就可以了。当我们点击的时候,我用的是个alert事件。事实上, 把this._num+1这个数字写入到数据库中,作为评分的依据就可以了
需要的两张图片:
<!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-Type" content="text/html; charset=utf-8" />
<title>脚本之家_www.jb51.net_阿当制作选星星打分 </title>
<style type="text/css">
.starWrapper{border:1px solid #FFCC00;padding:5px;width:70px;}
.starWrapper img{cursor:pointer;}
</style>
<script type="text/javascript">
function rate(obj,oEvent){
//==================
// 图片地址设置
//==================
var imgsrc='http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif'; //没有填色的星星
var imgSrc_2 = 'http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851730.gif'; //打分后有颜色的星星
//---------------------------------------------------------------------------
if(obj.rateFlag) return;
var e = oEvent || window.event;
var target = e.target || e.srcElement;
var imgArray = obj.getElementsByTagName("img");
for(var i=0;i <imgArray.length;i++){
  imgArray._num = i;
  imgArray.onclick=function(){
    if(obj.rateFlag) return;
    obj.rateFlag=true;
    alert(this._num+1);      //this._num+1这个数字写入到数据库中,作为评分的依据
  };
}
if(target.tagName=="IMG"){
  for(var j=0;j <imgArray.length;j++){
    if(j <=target._num){
    imgArray[j].src=imgSrc_2;
    } else {
    imgArray[j].src=imgSrc;
    }
  }
} else {
  for(var k=0;k <imgArray.length;k++){
    imgArray[k].src=imgSrc;
  }
}
}
</script>
<body>
<p class="starWrapper" onmouseover="rate(this,event)">
          <img src=http://www.9php.com/archiver/"http://www.knowsky.com/http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif" title="很烂" /> <img src=http://www.9php.com/archiver/"http://www.knowsky.com/http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif" title="一般" /> <img src=http://www.9php.com/archiver/"http://www.knowsky.com/http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif" title="还好" /> <img src=http://www.9php.com/archiver/"http://www.knowsky.com/http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif" title="较好" /> <img src=http://www.9php.com/archiver/"http://www.knowsky.com/http://www.9php.com/FAQ/UploadPic/2011/11/14/2011111419851536.gif" title="很好" />

</body>
</html>


本篇发布于:百家学院 (http://www.9php.com),复制请注明.

·看过 js实现星星打分效果 实现星星打分效果 文章的还看过:

·百家学院 | 最新评论·

评论内容:不能少于5个字,请自觉遵守互联网相关政策法规。

用户名: 验证码: 验证码,看不清楚?请点击刷新验证码