0

我试图想出一些 html 和 javascript 来更新多个垂直条。我已经能够通过以下方式让它工作 1 个酒吧:

javascript

$('#inner').animate({height: + Math.floor(Math.random()*100) + "%"},500);

css

#outer {
width: 15px;
height: 140px;
border: 2px solid #ccc;
overflow: hidden;
position: relative;
}

#inner, #inner div {
width: 100%;
overflow: hidden;
left: -2px;
position: absolute;
}

#inner {
border: 2px solid #000;
border-top-width: 0;
background-color: #090;

bottom: 0;
height: 0%;
}

#inner div {
border: 1px solid red;
border-bottom-width: 0;
background-color: orange;

top: 0;
width: 100%;
height: 5px;
}

html

<div id="outer>
     <div id="inner">
     <div>height:'0%'</div>
     </div> 
</div>

我想要做的是更新多个条形图,如下所示:

javascript

var number_of_bars=30;
for (var i=0; i<number_of_bars; i++) {
    $('#inner_'+ i).html('height:' + Math.floor(Math.random()*100) + "%");
}

但我需要让它引用特定的个人 div。任何人都可以帮忙吗?

4

2 回答 2

1

这是工作演示js-fiddle

javascript 不是最佳的,我刚刚复制了您的代码。

js

function reload(){
    $('.inner').each(function(){
        $(this).animate({
        height: +Math.floor(Math.random() * 100) + "%"
        }, 500);
    });
};

setInterval(reload, 1000);

html

<ul id="outer">
     <li style="height:100%;width:1px">&nbsp;</li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
    <li class="inner">
        <div>height:'0%'</div>
    </li>
</ul>

css

#outer {
    border: 2px solid #CCCCCC;
    height: 140px;
    overflow: hidden;
    padding: 0;
    position: relative;
}

#outer li {
    border: 1px solid lightgray;
    display: inline-block;
    height: 99%;
    overflow: hidden;
    position: inherit;
    width: 15px;
    background-color:green;
}

#outer li div{    
    bottom: 0;
    height: 0px;
    position: absolute;   
}
于 2013-05-06T08:46:37.133 回答
0
/**
 * Returns a random number between min and max
 */
function getRandomArbitary (min, max) {
    return Math.random() * (max - min) + min;
}

上面的函数是从在特定范围内的 JavaScript 中生成随机整数复制而来 的?

var number_of_bars=30;

var mini=100;
var maxi=$(window).height();

for (var i=0; i<number_of_bars; i++) {
    $('#inner_'+ i).html('height:' + getRandomArbitary (mini,maxi ) + "px");
}

我认为高度应该px不在,%这样它才能工作

于 2013-05-03T05:31:17.050 回答