基于jquery实现彩色投票进度条代码解析
程序员文章站
2022-03-02 23:39:32
一、需求如下图重点是要实现进度条。二、分析原理:动态设置
的子元素的宽度值。1、简单的雏形假设只有一个进度条,如下,我们只需要知道p元素的宽度,span元素的百...
一、需求
如下图
重点是要实现进度条。
二、分析
原理:动态设置<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>
最终效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: jQuery实现简单三级联动效果
推荐阅读
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
-
基于jquery实现彩色投票进度条代码解析
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码,jquerymysql
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码_php实例
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码_PHP
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码_php实例
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码_PHP
-
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码,jquerymysql_PHP教程