Для первой проблемы вы использовали разные средства для установки входов # minPrice / # maxPrice и #amount.Я очистил код, сделав его более читабельным, и сохранив объекты DOM и другие важные данные в переменных.Это повышает производительность и делает код намного проще для отладки.Этот рефакторинговый код всегда сообщает правильные значения из ползунка.
<script type="text/javascript">
$(document).ready(function() {
// Set increments for sale slider prices
var increments = ['0', '20,000', '40,000', '60,000', '80,000', '100,000', '120,000', '140,000', '160,000', '180,000', '200,000', '220,000', '240,000', '260,000', '280,000', '300,000', '320,000', '340,000', '360,000', '380,000', '400,000', '420,000', '440,000', '460,000', '480,000', '500,000', '520,000', '540,000', '560,000', '580,000', '600,000', '620,000', '640,000', '660,000', '680,000', '700,000', '720,000', '740,000', '760,000', '780,000', '800,000', '820,000', '840,000', '860,000', '880,000', '900,000', '920,000', '940,000', '960,000', '980,000', '1,000,000', '1,100,000', '1,200,000', '1,300,000', '1,400,000', '1,500,000', '1,600,000', '1,700,000', '1,800,000', '2,000,000'];
var amount = $('#amount');
var minPrice = $('#minPrice');
var maxPrice = $('#maxPrice');
var slider = $('#sliderPriceSale');
var initValuesMinIndex = $.inArray(minPrice.val(), increments); // Get index of value in #minPrice
var initValuesMaxIndex = $.inArray(maxPrice.val(), increments); // Get index of value in #maxPrice
var minPriceString = '';
var maxPriceString = '';
// Setup slider. Initialize #amount on creation.
slider.slider({
range: true,
min: 0,
max: 59,
step: 1,
values: [initValuesMinIndex, initValuesMaxIndex],
create: function() {
amount.val(increments[initValuesMinIndex] + " to " + increments[initValuesMaxIndex]);
},
slide: function (event, ui) {
// Get max/min price strings. If max price is == largest value append "+" sign.
minPriceString = increments[ui.values[0]];
maxPriceString = (increments[ui.values[1]] == increments[increments.length-1]) ? increments[ui.values[1]] + "+" : increments[ui.values[1]];
amount.val(minPriceString + " to " + maxPriceString);
minPrice.val( increments[ui.values[0]] );
maxPrice.val( increments[ui.values[1]] );
}
});
});
</script>
Что касается второй проблемы, трудно сказать точно, как вам следует этого достичь, не видя остальную часть вашего кода, но в целом все, что у вас естьчтобы сделать это, убедитесь, что скрытые переменные #maxPrice и #minPrice установлены на правильные значения при загрузке страницы, и ползунок будет автоматически отображать правильную информацию, когда он создается, поскольку он проверяет эти значения при создании.Например, если вы используете PHP и отправляете форму через POST, вы можете использовать следующий код для этих скрытых переменных:
<!-- Output minPrice & maxPrice values. Default to 80,000 and 300,000 respectively -->
<input type="hidden" id="minPrice" name="minPrice" value="<?php echo (isset($_POST['minPrice'])) ? $_POST['minPrice'] : '80,000'; ?>" />
<input type="hidden" id="maxPrice" name="maxPrice" value="<?php echo (isset($_POST['maxPrice'])) ? $_POST['maxPrice'] : '300,000'; ?>" />