jquery——彩色投票进度条

一、需求

如下图

重点是要实现进度条。

二、分析

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>

最终效果:

 

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4958786.html有问题欢迎与我讨论,共同进步。

时间: 2024-09-13 09:16:40

jquery——彩色投票进度条的相关文章

jquery彩色投票进度条简单实例演示_jquery

一.需求 如下图 重点是要实现进度条. 二.分析 html5新增及删除标签一文中提到过html5新增了progress标签.但是肯定有兼容性问题.生成环境不适用,所以要模拟实现. 原理:动态设置<p>的子元素<span>的宽度值. 1.简单的雏形假设只有一个进度条,如下,我们只需要知道p元素的宽度,span元素的百分比,相乘即得到span的宽度,浏览器加载时动态设置span的宽度即可实现进度条的效果. <style> .long{width:100px;border:1

6款新颖的jQuery和CSS3进度条插件推荐_jquery

现在的网页功能越来越多,尤其是AJAX的广泛应用,进度条和Loading加载动画显得越来越重要了.下面给大家介绍几款比较新颖的jQuery和CSS3进度条Loading加载动画插件,希望对大家有帮助. 1.不同进度显示不同颜色的进度条 这款CSS3进度条和别的有所不同,他的主要特点是随着进度的变化,进度条的颜色会有所改变,这个和游戏中人物的生命值很相似. 2.纯CSS3实现的彩色进度条 该进度条利用了CSS3的颜色渐变属性,让进度条的色彩显得非常具有立体感. 3.jQuery Progress

jQuery实现的进度条效果_jquery

在某些特定的场景下,应用进度条效果,可以提高网站的人性化程度,能够让用户能够掌握进度,增加对进度的耐心,否则可能直接导致关闭页面,从来导致网站流失用户,下面就是用过jQuery实现的进度效果代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script src="http://libs.baidu.co

jQuery 页面载入进度条实现代码_jquery

上图展示了传统 Wordpress 模板在浏览器中的载入顺序,Loading 条的出现和消失分布于头尾. 如果我们在页面的不同位置放置多个 JS ,每个 JS 用于逐步增加 Loading 条的宽度,那么这个 Loading 条无疑会更具实用价值.它在一定程度上缓解了访客等待载入的枯燥感,同时还能客观反映页面载入的进度.若再配以 jQuery 内建的动画效果,其完全可以与浏览器自带的状态条媲美. 先来看一个演示:地址. 要得到演示上的进度条效果,首先,引入 jQuery 框架(一定要放在页头 <

WEBJX收集jQuery的加载动画和进度条插件

文章简介:精心挑选的8款jQuery 加载动画和进度条插件. 加载动画和进度条在网站和 Web 应用中的使用非常流行.虽然网速越来越快,但是我们的网站越来越复杂,同时用户对网站的使用体验的要求也越来越高.在内容加载缓慢的时候,使用时尚的加载动画和进度条告诉用户还有内容正在加载是一种非常好的方式.今天这篇文章向大家推荐8款基于jQuery实现的加载动画和进度条插件. Spin.js 最喜欢这款插件了,动画图片的长度.粗细.速度和角度都可以灵活控制,想要做成什么样都可以. 源码下载 在线演示 Per

jQuery实现进度条效果代码_jquery

在某些特定的场景下,应用进度条效果,可以提高网站的人性化程度,能够让用户能够掌握进度,增加对进度的耐心,否则可能直接导致关闭页面,从来导致网站流失用户,下面就是用过jQuery实现的进度效果代码. <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta nam

jquery插件uploadify实现带进度条的文件批量上传_jquery

有时项目中需要一个文件批量上传功能时,个人认为uploadify是快速简便的解决方案,分享给大家供大家参考,具体如下 先上效果图: 具体代码如下: 在页面中如下 完整页面代码 <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> <!DOCTYPE html> <

《jQuery、jQuery UI及jQuery Mobile技巧与示例》——7.7 技巧:使用进度条微件显示进程的状态

7.7 技巧:使用进度条微件显示进程的状态 当Web应用程序执行一个动作的持续时间超过大约两秒钟时,为用户显示动作状态是一个很好的做法.如果不知道动作的状态,通常会改变鼠标光标或显示一个旋转的效果. 在某些情况下,你能知道进程的进度.在这种情况下,最好尽可能准确地满足用户的期待.代码清单7-7介绍了jQuery UI的进度条(progressbar),可以使用它实现这样的目的. 代码清单7-7 将一个 元素转换为进度条 00 <!DOCTYPE html> 01 02 <html lan

基于HTML5 Ajax文件上传进度条如何实现(jquery版本)_AJAX相关

在上篇文章给大家介绍了这篇文章里面的后台Servlet.所以这里只看前台的JS代码. 首先HTML5用AJAX提交数据先要学习一个HTML5新增加的对象:FormData FormData 对象可以使用append 方法进行 key - value的数据添加,与以前我们常用的json不同的就是可以异步上传二进制文件. 1.FormDate对象的创建 var formData = new FormData(); 2.向 FormDate 对象添加数据 formData.append("catnam