JQuery UI Slider for time

后端 未结 4 1307
伪装坚强ぢ
伪装坚强ぢ 2020-12-24 03:24

Hi I need to implement a slider for 24 hour time range . I like to use jquery ui slider for this . I have written below code



        
4条回答
  •  一向
    一向 (楼主)
    2020-12-24 04:10

    Improving on Tatu's answer, to get the time range in "civilian time," with a 12 hour clock and AM and PM designations. Here is a JSFIDDLE

    *Update - I changed the code slightly so that the min value displays as "12:00 AM" and the max value displays as "11:59 PM." The fiddle is also updated...

        $( "#slider-range" ).slider({
                range: true,
                min: 0,
                max: 1440,
                step: 15,
                values: [ 600, 720 ], //or whatever default time you want
                slide: function(e, ui) {
                    var hours1 = Math.floor(ui.values[0] / 60);
                    var minutes1 = ui.values[0] - (hours1 * 60);
    
                    if(hours1.length == 1) hours1 = '0' + hours1;
                    if(minutes1.length == 1) minutes1 = '0' + minutes1;
                    if(minutes1 == 0) minutes1 = '00';
    
                    if(hours1 >= 12){
    
                        if (hours1 == 12){
                            hours1 = hours1;
                            minutes1 = minutes1 + " PM";
                        }
                        else{
                            hours1 = hours1 - 12;
                            minutes1 = minutes1 + " PM";
                        }
                    }
    
                    else{
    
                        hours1 = hours1;
                        minutes1 = minutes1 + " AM";
                    }
                    if (hours1 == 0){
                        hours1 = 12;
                        minutes1 = minutes1;
                    }
    
                    $('.slider-time').html(hours1+':'+minutes1);
    
                    var hours2 = Math.floor(ui.values[1] / 60);
                    var minutes2 = ui.values[1] - (hours2 * 60);
    
                    if(hours2.length == 1) hours2 = '0' + hours2;
                    if(minutes2.length == 1) minutes2 = '0' + minutes2;
                    if(minutes2 == 0) minutes2 = '00';
                    if(hours2 >= 12){
                        if (hours2 == 12){
                            hours2 = hours2;
                            minutes2 = minutes2 + " PM";
                        }
                        else if (hours2 == 24){
                            hours2 = 11;
                            minutes2 = "59 PM";
                        }
                        else{
                            hours2 = hours2 - 12;
                            minutes2 = minutes2 + " PM";
                        }
                    }
                    else{
                        hours2 = hours2;
                        minutes2 = minutes2 + " AM";
                    }
    
                    $('.slider-time2').html(hours2+':'+minutes2);
                }
        });
    

提交回复
热议问题