jQuery UI slider' change ' событие срабатывает, даже если значение не изменилось
Я пытаюсь запустить событие, когда пользователь скользит ползунок и значение изменяется, когда скольжение останавливается. Согласно документам jQuery,change
событие было бы идеальным для этого случая. Поэтому я пробую это:
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>jQuery UI Slider - Default functionality</title>
<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.2/themes/smoothness/jquery-ui.css" />
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.2/jquery-ui.js"></script>
<link rel="stylesheet" href="/resources/demos/style.css" />
<script>
$(function() {
$( "#slider" ).slider({
change:function() { alert("foo"); }
});
});
</script>
</head>
<body>
<div id="slider"></div>
</body>
</html>
однако я замечаю, что когда я перетаскиваю ползунок вправо и снова перетаскиваю его обратно в начальную точку (начальное положение ползунка при загрузке страницы), предупреждение все еще срабатывает. Это ошибка jQuery? Если нет, то как это исправить?
2 ответов
$(function() {
$("#slider").slider();
var startPos = $("#slider").slider("value");,
endPos = '';
$("#slider").on("slidestop", function(event, ui) {
endPos = ui.value;
if (startPos != endPos) {
// do stuff
}
startPos = endPos;
});
});
просто попробовать.
$(function() {
$("#slider").slider({
slide: function(event, ui) {
// use ui.value to get a number
// do your functions
}
});
});