成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? jquery彩色投票進度條簡單實例演示
全站頭部文字 我要出現在這里
jquery彩色投票進度條簡單實例演示 689 2024-03-20   

一、需求
如下圖

查看圖片

重點是要實現進度條。

二、分析
html5新增及刪除標簽一文中提到過html5新增了progress標簽。但是肯定有兼容性問題。生成環境不適用,所以要模擬實現。

原理:動態設置<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>

查看圖片

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實現。

查看圖片

第二步、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>

效果:

查看圖片

第三步,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>

最終效果:

查看圖片

以上就是彩色的進度條特效,特別適合用于投票,效果很明顯,希望對大家的學習有所幫助,會喜歡上這個彩色進度條。



主站蜘蛛池模板: 欧美一级黄色录像| 范艳华| 39天 电影| 单位同意报考证明| 红海行动2在线观看西瓜影院| 夫妻的情妇| 《摧花狂魔》电影| 内战电影免费观看2024年上映| 小清水亚美| 何国强| 太原教育电视台| 守株待兔评课| 丰原功补| 新版731部队电影免费| 董三毛| 萱草花合唱谱二声部| 屁屁视频| 欲盖弄潮电影| 《白蛇传说》| 情人意大利| 官网移动端充值| 乱世危情电视剧演员表| 山上的小屋免费阅读小说全文| 巩俐吻戏| 漂亮主妇 电视剧| 飞虎神鹰1-42集免费| 抗日名将卫立煌 电影| 红灯区未删减版| 情人电视剧| 迷案1937电视剧剧情介绍| 韩国三级播放| 时来运转电影| 巴霍巴利王3电影免费观看| 黄金传说| 欧美视频亚洲视频| 拨萝卜电视剧视频歌高清在线观看大牛 | 日本女人交配视频| 孔令辉简历及个人资料| 魔法少女砂沙美| jif| 纵横欲海|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103