如何根据当前的值更改noUiSliders的颜色?

时间:2016-11-22 00:29:53

标签: javascript jquery nouislider

所以我为我的滑块创建了一些自定义颜色类,它运行良好......这就是它的外观:

colored-sliders

我只是简单地创建了以下类:

.red .noUi-connect {
  background: #c0392b;
}

.orange .noUi-connect {
  background: #2980b9;
}

.green .noUi-connect {
  background: #27ae60;
}

并将它们应用到我的div中:

<div id="slider-speed" class="slider red"></div>
<div id="slider-speed" class="slider orange"></div>
<div id="slider-speed" class="slider green"></div>

但是,我想要做的是当用户向左或向右移动滑块时,滑块的颜色会根据值而改变。

所以1 - 3 =红色,4 - 6 =橙色,7 - 10 =绿色。

我该怎么做?

1 个答案:

答案 0 :(得分:2)

您可以尝试使用事件回调进行“更新”,如下所示:

slider.noUiSlider.on('update', function(values, handle){
  updateColorClass(document.getElementById('slider-speed'), values[handle]);
});

function updateColorClass(element, value) {
  var color;
  if (value < 4) { 
    color = 'red';
  } else if (value < 7) { 
    color = 'orange';
  } else {
    color = 'green';
  }

  element.classList.remove("red", "orange", "green");
  element.classList.add(color);
}