Maison > interface Web > js tutoriel > Exemple de création d'un simple graphique à barres avec jQuery_jquery

Exemple de création d'un simple graphique à barres avec jQuery_jquery

WBOY
Libérer: 2016-05-16 16:17:50
original
1687 Les gens l'ont consulté

L'exemple de cet article décrit comment créer un histogramme simple avec jQuery. Partagez-le avec tout le monde pour votre référence. La méthode de mise en œuvre spécifique est la suivante :

Partie HTML :

Copier le code Le code est le suivant :
Histogramme




Partie CSS :




Copier le code

Le code est le suivant :
/*Ce qui suit est le style d'histogramme*/

.histogram-container{position:relative;margin-left:60px;margin-top:10px;margin-bottom:25px;} .histogram-bg-line{border:#999 solid;border-width:0 0px 1px 1px;border-right-color:#eee;overflow:hidden;width:99%;} .histogram-bg-line ul{overflow:hidden;border:#eee solid;border-width:1px 0 0 0;clear:both;} .histogram-bg-line li{float:left;overflow:hidden;background:#fff;} .histogram-bg-line li div{border-right:1px #eee solid;} .histogram-content{position:absolute;left:0px;top:0;width:99%;height:100%;} .histogram-content ul{hauteur:100%;}
.histogram-content li{float:left;height:100%;text-align:center;position:relative;}
.histogram-box{position:relative;display:inline-block;height:100%;width:20px;}
.histogram-content li a{position:absolute;bottom:0;right:0;display:block;width:20px;font-size:0;line-height:0;}
.histogram-content li .histogram-name{position:absolute;bottom:-20px;left:0px;white-space:nowrap;display:inline-block;width:100%;font-size:12px;overflow:hidden; }
.histogram-y{position:absolute;left:-60px;top:-10px;font:12px/1.8 verdana,arial;}
.histogram-y li{text-align:right;width:55px;padding-right:5px;color:#333;}
.histogram-bg-line li div,.histogram-y li{height:30px;/*Contrôlez la hauteur de la cellule et la hauteur du pourcentage, afin que le pourcentage et la ligne soient alignés*/}



Partie Js :




Copier le code

Le code est le suivant :


$(fonction(){
var dataArr={
"données":[
{"id":1,"name":"Baidu","per":"10"},
{"id":2,"name":"Tencent","per":"20"},
{"id":3,"name":"Sina","per":"10"},
{"id":4,"name":"NetEase","per":"44"},
{"id":5,"name":Sohu","per":"50"},
              {"id":5,"name":"Petit Gobie","per":"69"},
{"id":5,"name":"人人网","per":"72"},
{"id":5,"name":iQiyi","per":"88"},
{"id":5,"name":"Qihoo 360","per":"92"},
{"id":5,"name":"Alibaba","per":"15"},
{"id":5,"name": "Alibaba", "per": "10"}
] ]
};
new histogram().init(dataArr.data);
});

fonction histogramme(){
var contrôles={};
var bgColor=nouveau tableau("#666666","#21AA7C","#2277BB","#dc7644","#BBAA22","#AA22AA","#338800","#1099EE","#ffcc33" ,"#ED3810");
This.init=function(data,y){
setControls();
        buildHtml(data,y);
}  
Fonction setControls(){
contrôles.histogramContainer=$("#histogram-container");
controles.histogramBgLineUL=controls.histogramContainer.children("div.histogram-bg-line"); controles.histogramContentUL=controls.histogramContainer.children("div.histogram-content"
); CONTROLS.histogramY=controls.histogramContainer.children("div.histogram-y"); }  
Fonction buildHtml(data,y){
      var len=data.length,perArr=new Array(),maxNum,maxTotal,yStr=''
      var contentStr='',bgLineStr='',bgLineAll=''
var widthPer=Math.floor(100/len);
          minWidth=len*21 60 ;          controls.histogramContainer.css("min-width",minWidth "px");                                                                         pour(var a=0;a              perArr[a]=parseInt(data[a]['per']);                                                                                                                                                    maxNum=String(perArr.max());
Si(maxNum.length>2){
            var x=parseInt(maxNum.substr(maxNum.length-2,1)) 1;  
               maxTotal=Math.floor(parseInt(maxNum/100))*100 x*10;
          }autre{ 
                 maxTotal=Math.floor(parseInt(maxNum/10))*10 10 ;                                                                                                                                                                                                    //partie de l'axe Y
Si(y=="%"){
yStr ='
  • 100 %
  • 80 %
  • 60 %
  • 40 %
  • 0 %
  • ';           }autre{ 
                var avg=maxTotal/5;  
    pour(i=5;i>=0;i--){
                    yStr ='
  • ' moy*i '
  • '; 
                } 
            } 
             
            //柱状条部分 
            pour(var i=0;i             var per=Math.floor(parseInt(data[i]['per'])/maxTotal*100); 
                var n=Math.floor(parseInt(per)/10); 
                contentStr ='
  • '; 
                contentStr ='' data[i]['nom'] ''; 
                contentStr ='
  • '; 
                bgLineStr ='
  • '; 
            } 
             
            //背景方格部分 
            pour(var j=0;j<5;j ){ 
                bgLineAll ='
      ' bgLineStr '
    '; 
            } 
            bgLineAll='
    ' bgLineAll '
    '; 
            contentStr='
      ' contentStr '
    '; 
            yStr='
      ' yStr '
    '; 
            controles.histogramContainer.html(bgLineAll contentStr yStr); 
            CONTROLS.histogramContainer.css("height",controls.histogramContainer.height() "px");//主要是解决IE6中的问题       
        } 

    Array.prototype.max = function(){//最大值 
     return Math.max.apply({},this)  
    >

    希望本文所述对大家的jQuery程序设计有所帮助。

    Étiquettes associées:
    source:php.cn
    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
    Tutoriels populaires
    Plus>
    Derniers téléchargements
    Plus>
    effets Web
    Code source du site Web
    Matériel du site Web
    Modèle frontal