预约用里程碑式进度条与人数渐增效果

80 阅读2分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

预约类型的活动常见的一个效果,若是里程碑点按进度条比例分割的话实现起来就很简单,只需要放在相应的百分比点位然后控制进度条长度即可,但要是里程碑值不是等比的还要均分进度条的实现起来就很麻烦了。

例如:

预约数要求为:1000, 3000, 5000,10000;

  • 如果点位也在10%,30%,50%,100%处;那么对应的进度条长度10%,30%,50%,100%即可。

  • 但要是点位均匀分布在进度条的25%,50%,75%,100%处,这种情况还想实现效果就很麻烦了。

下面提供我的实现思路

效果预览

在这里插入图片描述

人数渐增与进度条是独立的函数可以分开使用,动画执行时间设置为相同时间即可。

思路

将进度条按里程碑分为不同阶段,然后按人数取不同阶段进行填充即可,

例如:现在有2300人这时候超过了阶段1(1000人)低于阶段2(3000人)这个阶段,那么要取人数在阶段1到阶段2这一截的真实进度就需要先扣掉填满阶段1所用的人数,再除以阶段1到阶段2中间的人数。

即:(2300 - 阶段1用掉的人数) / (阶段2人数 - 阶段2人数) = 百分比;

请添加图片描述

// 示例如下,
num = 2000 // 当前人数为2000:
length = ['0-1000的长度', '0-3000的长度', '0-5000的长度', '0-10000的长度'];
countArr=[1000,3000,5000,10000] // 每个阶段的人数
  
var w = length[1] - length[0], // 1000-3000这一段的长度
    diff = countArr[1] - countArr[0],  //1000-3000中间的人数
    realPeople = num - countArr[0], // 当前人数在这个阶段的数量
    percentage = realPeople / diff; // 当前人数在这个阶段的占比
 
progress.css(direction, w * percentage + length[0] + 'px')

我的个人公众号:归园田居 每日分享前端知识与资讯~