使用这个问题的第二个答案,我为 4 句柄 jquery 滑块编写了代码。它工作正常,但后来我不得不在同一页面中制作多个滑块,所以我尝试对我的代码进行一些模块化,将幻灯片功能分开。现在滑块中的处理程序完全重叠,忽略了我为这种情况设置的条件。
这是我的幻灯片功能的代码以及我如何在滑块设置中调用它:
滑动功能:
function slidegen(event,ui,index){
//Code for handler 0
if(ui.handle == $("#weightage_slider_"+index+"_0").get(0)){
if(ui.values[0] >= ui.values[1]){
/*FOR SOME REASON THE NEXT LINE HAS NO EFFECT*/
$("#weightage_slider_"+index).slider('values', 0, ui.values[1]);
return false;
} else {
// handle-0 will move
// update display of colored handle ranges
$("#weightage_slider_a_"+index).css('left', '0%');
$("#weightage_slider_a_"+index).css('width', (to100(ui.values[0])+'%'));
$("#weightage_slider_b_"+index).css('left', (to100(ui.values[0])+'%'));
$("#weightage_slider_b_"+index).css('width', ((to100(ui.values[1])-to100(ui.values[0]))+'%'));
}
}
/*SIMILAR CODE FOR THE REST OF THE HANDLERS HERE*/
}
滑块设置:
$("#weightage_slider_0").slider({
min: 1,
max: 5,
step: 0.01,
values: handlers, // set four handles
slide: function(event, ui) {
slidegen(event,ui,0);
},
change: function(event, ui) {
changen(event,ui,0);
}
});
我知道在滑动期间,会发生以下顺序:(i)更改 ui.value(ii)调用滑块函数(iii)移动滑块句柄。可能是因为我在滑块函数内部进行了另一个调用,所以发生了错误,因此我正在改变那个顺序?