麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jquery彩色投票進度條簡單實例演示

2019-11-20 11:11:21
字體:
來源:轉載
供稿:網友

一、需求
如下圖

重點是要實現進度條。

二、分析
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>

最終效果:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美日韩专区国产精品 | 免费观看一区二区三区视频 | 欧美黄色免费视频 | 国产精品久久久久久婷婷天堂 | 久久免费视频精品 | 欧美2区 | 人人做人人看 | 91精品国产综合久久青草 | 中文字幕国产欧美 | 一区二区高清视频在线观看 | 中文欧美日韩 | 久久艹国产精品 | 九九热精品免费 | 亚洲热线99精品视频 | 国产高潮失禁喷水爽到抽搐视频 | 欧美14一15sex性hd | 亚洲第一页综合 | 蜜桃网在线观看 | 免费99热在线观看 | 免费观看一区 | 精品成人在线 | 福利四区 | 青热久思思 | 日韩视频一区二区三区四区 | 欧美日韩综合视频 | 久久蜜臀一区二区三区av | 精品国产一区二区三区久久久蜜月 | 在线小视频国产 | xxxx hd video 69 | 久久精品一区二区三区四区五区 | 久久国产免费 | 日韩精品二区 | 成人偷拍片视频在线观看 | 久久精品2019中文字幕 | 久久免费观看一级毛片 | 久草视频在线资源 | 亚洲综合中文 | 黄色av网站免费 | 久久国产精品二国产精品 | 亚洲一区二区三区视频免费 | 国产精品欧美日韩一区二区 |