>웹 프론트엔드 >JS 튜토리얼 >Jquery 색상 투표 진행률 bar_jquery의 간단한 예제 데모

Jquery 색상 투표 진행률 bar_jquery의 간단한 예제 데모

WBOY
WBOY원래의
2016-05-16 15:30:291528검색

1. 수요
아래와 같이

진행률 표시줄을 구현하는 것이 핵심입니다.

2. 분석
"html5에서 태그 추가 및 삭제" 기사에서 html5에 새로운 진행 태그가 추가되었다고 언급되었습니다. 하지만 확실히 호환성 문제가 있습니다. 프로덕션 환경이 적합하지 않으므로 구현을 시뮬레이션해야 합니다.

원리: e388a4556c0f65e1904146cc1a846bee의 하위 요소 45a2772a6b6107b401db3c9b82c049c2의 너비 값을 동적으로 설정합니다.

1. 간단한 프로토타입
아래와 같이 진행률 표시줄이 하나만 있다고 가정합니다. 브라우저가 로드될 때 p 요소의 너비와 범위 요소의 백분율만 알면 됩니다. 진행률 표시줄의 효과를 얻기 위해 범위의 너비를 동적으로 설정할 수 있습니다.

<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. 투표 진행 표시줄 구현 과정
1단계: 구조는 다음과 같습니다

<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>

스팬에 너비와 배경색을 추가하여 진행률 표시줄 효과를 만듭니다. 이 단계는 js를 사용하여 구현됩니다.

두 번째 단계는 js로 스팬 너비를 설정하는 것입니다

<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는 스팬의 배경색을 설정합니다
두 번째 단계의 배경색은 아래와 동일하게 설정됩니다.

$(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>

최종 효과:

위는 컬러 진행률 표시줄의 특수 효과로, 특히 투표에 적합합니다. 모든 사람의 학습에 도움이 되기를 바라며 이 컬러 진행률 표시줄을 좋아하실 것입니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.