搜索:
首页 >> JavaScript >> Js高级编程 >> 发个选星星打分/投票功能函数

发个选星星打分/投票功能函数

2008-5-22 作者:阿当 来源:经典论坛 投递文章

看了下传统的方法,觉得不好,太麻烦。自己重写了个,思路比较新。

这个函数的优点是html代码可以很简洁,使用图片也可以很少,只需要两张图片。事件句柄只需要写在img的父容器上即可。演示用的图片我用的是绝对地址,各位在使用的时候改成网站的相对地址就可以了。当我们点击的时候,我用的是个alert事件。事实上,我们会在这个地方用个ajax方法,把相关的参数传到服务器端。只要把alert(this._num+1)写成sendAjax(this._num+1)就可以了。

//====================选星星打分功能================= 
function rate(obj,oEvent){
//==================
// 图片地址设置
//==================
var imgSrc = '/article/UploadPic/20085/22/2008522124416586.gif';
var imgSrc_2 = '/article/UploadPic/20085/22/2008522124419196.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[i]._num = i;
   imgArray[i].onclick=function(){
    if(obj.rateFlag) return;
    obj.rateFlag=true;
    alert(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;
   }
}
}

函数有两个参数,功能如下:

obj:  img标签组的父容器,类型为DOM对象;

oEvent: event对象。

[提示:你可先修改部分代码,再按运行]


 

Tags:打分  投票  函数 
相关文章
手机版 Js高级编程 Asp之家 Aspxhome.com
闽ICP备06017341号