我正在尝试开发一个分数栏,用户可以在其中查看他的分数,还可以看到他可以赢得的最高奖金的进度。

问题是在这个酒吧有8个奖项,每个奖项都有不同的奖励点。您可以通过仅收集200点来赢得小奖,或者可以通过收集50000点来赢得旅行。

现在的问题是我必须在栏上显示所有八个奖项里程碑,并且每个奖项里程碑之间的间隔都相同

如您所见,图片用户赢得了7800分,他现在达到了7500的里程碑,主要问题是我必须获得这些点之间的比率才能将瓶子放置在我做不到的准确位置上:(我努力了,但是nothig发生了

您可以在这里看到 fiddle :http://jsfiddle.net/Udwq9/2/

的HTML

<p>&nbsp;</p><p>&nbsp;</p><p>&nbsp;</p><p>&nbsp;</p>

<div class="barCont">
      <div class="innerLight"></div>
      <div class="innerDark"> </div>
      <div class="seek">
        <div class="youRhere">
          <p>You are here:<br />
            <span id="Points">7800 Points</span></p>
          <br />
        </div>
        <img src="" width="17" height="74" alt=" " /> </div>
      <div class="mileStone" style="">200

      </div>
      <div class="mileStone" style="">300

      </div>
      <div class="mileStone" style="">450

      </div><div class="mileStone" style="">750

      </div>
      <div class="mileStone" style="">7500

      </div>
      <div class="mileStone" style="">15000

      </div>
      <div class="mileStone" style="">20000

      </div><div class="mileStone" style="">50000

      </div>
    </div>

脚本
var TopScore = 50000;
    var MileStone = new Array("200", "300", "450", "750", "7500", "15000", "20000", "50000");
    var barWidth = $('.innerLight').width();
    var ArrayLength = MileStone.length;
    var milestonepos = barWidth/ArrayLength;
    var milestoneposMain = milestonepos/ArrayLength;
    var Points = $('#Points').text();
    var yourPoints = parseInt(Points);
    var pos = 0;
    var bottlePos = 0;
    var posTwo = 0;
    var posTwoMain = 0;

    for(var i=0; i <= ArrayLength; i++){
        var pos = pos + milestonepos;
        $('.mileStone').eq(i).animate({ left: '' + pos + 'px' });
        //alert(pos)
        }
    var pos = 0;
    for(var j=0; j<= ArrayLength; j++){
        if(yourPoints >= MileStone[j])
        {

        var pos = pos + milestonepos;

             /*var step1 = yourPoints - MileStone[j];
             var step2 = MileStone[j+1] - yourPoints;
             var step3 = step2/step1;
             var step4 = step3*100;*/
            // var pointsRatio = yourPoints - posRatio;
             //var posTwoMain = parseFloat(posTwo.style.width)
             //alert(parseInt(posRatio));
             //alert(parseInt(pointsRatio));
            // var pos = pos + pointsRatio;
            }

        }
        $('.seek').animate({ left: '' + parseInt(pos) + 'px' }, 1000);

最佳答案

看起来似乎不太困难,但是7800并不是一个值得测试的值,因为它在7500到15000的范围内几乎与7500无关。(因此在JSfiddle中,我将其更改为12700)。

http://jsfiddle.net/Udwq9/9/

我修改为第二个for循环,以在里程碑大于用户得​​分时中断。

for(var j=0; j < ArrayLength; j++)
{
    if(yourPoints >= MileStone[j])
    {
        pos = pos + milestonepos;
    }
    else
    {
        prevMilestone = j ? MileStone[j-1] : 0;
        pos += parseInt( (yourPoints-prevMilestone)/(MileStone[j]-prevMilestone) * milestonepos);
        break;
    }
}

关于jquery - 使用jQuery获取两个数组的比率,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21189821/

10-11 06:07