分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 网页技术

js并列排名之div图片加载

发布时间:2023-09-06 02:30责任编辑:郭大石关键词:jsdiv

今天遇到的问题基于上一次的代码:

当投票数相同后,比如最多的都是38票,有三人,此时,改成39时,排名依然是三个第一名

错误代码

if(j<countList.length){
if(countList[j].text===countList[j+1].text){
num[j+1].style.backgroundImage=num[j].style.backgroundImage;
}
}

这里仅仅是对相邻两个票数作比较,且由于num[j].style.backgroundImage;是动态获得的,也就是要更改的图片并不在num中存放,再怎么赋新值也是基于当前情况,因此我的解决办法是先存储图片

var numImg = new Array();
numImg[0]="url(‘/voteonline/img/num/1.png‘)";
numImg[1]="url(‘/voteonline/img/num/2.png‘)";
numImg[2]="url(‘/voteonline/img/num/3.png‘)";
numImg[3]="url(‘/voteonline/img/num/4.png‘)";
numImg[4]="url(‘/voteonline/img/num/5.png‘)";
numImg[5]="url(‘/voteonline/img/num/6.png‘)";
numImg[6]="url(‘/voteonline/img/num/7.png‘)";
numImg[7]="url(‘/voteonline/img/num/8.png‘)";
numImg[8]="url(‘/voteonline/img/num/9.png‘)";
numImg[9]="url(‘/voteonline/img/num/10.png‘)";

这时赋值就是相对初始情况了。

同时,不再是两两比较,而是当前对象与之后的所有对象比较,虽然会出现重复赋值的情况,但可以避免后面出现票数相同,但名次却不同的情况

for (var j = 0; j < countList.length; j++) {
count[j].innerHTML = countList[j].text;
for(var k=j+1;k< countList.length; k++){
if(countList[j].text==countList[k].text){
num[k].style.backgroundImage=num[j].style.backgroundImage;
}else{
num[k].style.backgroundImage=numImg[k];
}
}

}

js并列排名之div图片加载

原文地址:https://www.cnblogs.com/xz-404/p/10289573.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved