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

基于jquery实现彩色投票进度条代码解析

程序员文章站 2022-03-02 23:39:32
一、需求如下图重点是要实现进度条。二、分析原理:动态设置

的子元素的宽度值。1、简单的雏形假设只有一个进度条,如下,我们只需要知道p元素的宽度,span元素的百...

一、需求

如下图

基于jquery实现彩色投票进度条代码解析

重点是要实现进度条。

二、分析

原理:动态设置<p>的子元素<span>的宽度值。

1、简单的雏形

假设只有一个进度条,如下,我们只需要知道p元素的宽度,span元素的百分比,相乘即得到span的宽度,浏览器加载时动态设置span的宽度即可实现进度条的效果。

<style>
.long{width:100px;border:1px solid #7f7f7f;height:14px;background-color:#d6d6d6;}
.short{float:left;height:14px;background-color:#0ff;}
</style>

<body>
<p class="long"><span class="short"></span></p>
<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>
var percent=0.5;
var longwidth=100;
var shortwidth=percent*longwidth;

$(".short").animate({width:shortwidth+"px"},'slow');

</script>
</body>

基于jquery实现彩色投票进度条代码解析

2、投票进度条实现过程

第一步:

结构如下

<meta charset="utf-8">
<style>
/*样式重置*/
ul,h4,p{margin:0;padding:0;}
/*清除浮动*/
.clearfix:after{visibility:hidden;display:block;font-size:0;content:" ";clear:both;height:0;}

body { font: 12px/1.5 arial, 宋体; }
html, body { color: #333333; }
/*投票css*/
.vote-box-list{border:1px solid red;position:absolute;}
.vote-box-list li{list-style:none;margin:10px 0;}
.vote-item-wrap h4,.vote-item-wrap .vnum{float:left;font-size:14px;font-weight:normal;line-height:16px;}
.vote-item-wrap p{float:left;height:14px;width:200px;border:1px solid #e2e2e2;background-color:#efefef;margin:0 10px;}
.vote-item-wrap p span{float:left;height:14px;/*width:30px;background-color:#c2f263;*/}
</style>
<ul class="vote-box-list clearfix" id="appvotebox">
 <li class="vl-item" id="voteitem0">
  <div class="vote-item-wrap clearfix">
   <h4>a:</h4>
   <p class="litem"><span></span></p>
   <span class="vnum">79(2%)</span>
  </div>
 </li>
 <li class="vl-item" id="voteitem1" >
  <div class="vote-item-wrap clearfix">
   <h4>b:</h4>
   <p class="litem"><span></span></p>
   <span class="vnum">1986(61%)</span>
  </div>
 </li>
 <li class="vl-item" id="voteitem2">
  <div class="vote-item-wrap clearfix">
   <h4>c:</h4>
   <p class="litem"><span></span></p>
   <span class="vnum">1153(36%)</span>
  </div>
 </li>
 <li class="vl-item" id="voteitem3" >
  <div class="vote-item-wrap clearfix">
   <h4>d:</h4>
   <p class="litem"><span></span></p>
   <span class="vnum">415(13%)</span>
  </div>
 </li>
 <li class="vl-item" id="voteitem4" >
  <div class="vote-item-wrap clearfix">
   <h4>e:</h4>
   <p class="litem"><span></span></p>
   <span class="vnum">89(3%)</span>
  </div>
 </li>
</ul>

给span增加一个width和背景色,就可以出现进度条的效果。这一步用js实现。

基于jquery实现彩色投票进度条代码解析

第二步、js设置span的宽度

<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>

var vote={};
vote.listshow=(function(){
  var longwidth;
  var percentarr=[];
  var shortwidth=[];
  var spanarr=[];
  
  /*初始化*/
  function init(o){
    voteid=o.id;
    longwidth=o.width;
    percentarr=o.percent;
    shortwidth=calwidth();
    spanarr=findspans();
  }
  /*根据百分比计每个算span的实际宽度*/
  function calwidth(){
    var arr=[];
    for(var i=0;i<percentarr.length;i++){
      var templength=percentarr[i]*longwidth;
      arr.push(templength);
    }
    return arr;
  }
  /*将全部span存为一个数组*/
  function findspans(){
    var litems=$("#"+voteid).find(".litem");
    var arr=[]
    for(var i=0;i<litems.length;i++){
      arr.push(litems[i].children[0]);
    }
    return arr;
  }
  /*每个span元素设置宽度*/
  function setwidth(){
    for(i=0;i<percentarr.length;i++){
      $(spanarr[i]).animate({width:shortwidth[i]+"px"},'slow');
      $(spanarr[i]).css({'background-color':"#c2f263"}); 
    }
    
  }
  return {init:init,set:setwidth};
})();

/*调用*/
vote.listshow.init(
{
  id:'appvotebox',
  width:200-2 ,
  percent:[0.02,0.61,0.36,0.13,0.3],
});
vote.listshow.set();

</script>

效果:

基于jquery实现彩色投票进度条代码解析

第三步,js设置span的背景色

第二步中的背景色都是如下设置为一样。

$(spanarr[i]).css({'background-color':"#c2f263"});

现在随机生成背景色,做一个彩色的进度条。

<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>

var vote={};
vote.listshow=(function(){
  var longwidth;
  var percentarr=[];
  var shortwidth=[];
  var spanarr=[];
  var colorarr=[];
  
  /*初始化*/
  function init(o){
    voteid=o.id;
    longwidth=o.width;
    percentarr=o.percent;
    shortwidth=calwidth();
    spanarr=findspans();
    colorarr=gencolor();
  }
  /*根据百分比计每个算span的实际宽度*/
  function calwidth(){
    var arr=[];
    for(var i=0;i<percentarr.length;i++){
      var templength=percentarr[i]*longwidth;
      arr.push(templength);
    }
    return arr;
  }
  /*将全部span存为一个数组*/
  function findspans(){
    var litems=$("#"+voteid).find(".litem");
    var arr=[]
    for(var i=0;i<litems.length;i++){
      arr.push(litems[i].children[0]);
    }
    return arr;
  }
  /*o是颜色数组,随机选择length种颜色返回*/
  function gencolor() { 
    var o = []; 
    var n = ["#5dbc5b", "#6c81b6", "#9eb5f0", "#a5cbd6", "#aee7f8", "#c2f263", "#d843b3", "#d8e929", "#e58652", "#e7ab6d", "#ee335f", "#fbe096", "#ffc535"]; //彩色进度条
    var colorsarr = n.slice(); 
    for (var i = 0;i < percentarr.length; i++){ 
      //math.random()返回0.0 ~ 1.0 之间的一个伪随机数。
      //math.floor()向下取整
      var k = math.floor(math.random()* colorsarr.length); 
      o.push(colorsarr[k]); 
      //取完一种颜色后就从颜色数组中删除
      colorsarr.splice(k, 1); 
      if (colorsarr.length == 0){ 
      colorsarr = n.slice()} 
    } 
    return o;
  } 
  /*每个span元素设置宽度*/
  function setwidth(){
    for(i=0;i<percentarr.length;i++){
      $(spanarr[i]).animate({width:shortwidth[i]+"px"},'slow');
      $(spanarr[i]).css({'background-color':colorarr[i]}); 
    }
    
  }
  return {init:init,set:setwidth};
})();

/*调用*/

vote.listshow.init(
{
  id:'appvotebox',
  width:200-2 ,
  percent:[0.02,0.61,0.36,0.13,0.3],
});
vote.listshow.set();

</script>

最终效果:

基于jquery实现彩色投票进度条代码解析

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。