1. 程式人生 > 程式設計 >基於jquery實現彩色投票進度條程式碼解析

基於jquery實現彩色投票進度條程式碼解析

一、需求

如下圖

基於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',});
Vote.ListShow.set();

</script>

最終效果:

基於jquery實現彩色投票進度條程式碼解析

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。