jquery ui- (слайдер) привязка пользовательских событий не работает
У меня возникла небольшая проблема, связанная с выяснением, почему мое пользовательское событие не запускается и не работает правильно... Мое пользовательское событие должно быть прикреплено к каждому столбцу, как я могу привязать ползунок только к одному столбцу (объект cols ниже)? С моим текущим кодом, если я нажму на любое col, все cols изменятся...
Я пытаюсь динамически изменить размер столбца таблицы с помощью ползунка, который открывается внутри небольшого div, если щелкнуть таблицу, мой маленький диалог загружается, чтобы получить всю текущую ширину столбца и добавить обработчик события, мой код:
//param: data = current table
function DisplayColumnData(data) {
var cols = $(data).find("col");
//attach slider to each col
$(cols).each(function(i) {
var that = this;
var coldata = $("<div class='ui-col-data' />");
var colvalue = $("<span class='ui-col-value' />");
colvalue.text($(that).attr("width"));
coldata.text(" >col" + i + ": ").append(colvalue);
$(".ui-resizer-cols").append(coldata);
//handle column resizing, bind each col to the slider...
$(coldata).click(function() {
$(".ui-col-data").unbind("resizehandler");
//remove all other binded events then trigger the new event only...
$(coldata).trigger("resizehandler", that);
});
});
}
$(".ui-col-data").live("resizehandler", function(event, data) {
var $parent = $(this).closest(".ui-resizer-cols");
//remove classes from all other cols so only the clicked col is resized
$parent.find(".ui-col-data").removeClass("ui-col-border");
$parent.find(".ui-col-value").removeClass("ui-resizer-val");
$(this).addClass("ui-col-border"); //now the active col
var valfield = $(this).find("span.ui-col-value");
valfield.addClass("ui-resizer-val");
//update whatever...
$("#ui-resizer").slider('value', valfield.text() );
$("#ui-resizer").bind("slide", function(e, ui) {
valfield.text(ui.value);
$(data).attr("width", ui.value); //update col
});
});
ТАБЛИЦА:
<table>
<colgroup>
<col width="25%">
<col width="25%">
<col width="25%">
<col width="25%">
</colgroup>
<tbody>
<tr>...</tr>// 4 td's here as normal
<tr>...</tr>
</tbody>
</table>
Slider:
<div class="ui-resizer-content">
<div id="ui-resizer" class="ui-slider ui-slider-horizontal ui-widget ui-widget-content ui-corner-all">
<div class="ui-slider-range ui-slider-range-max ui-widget-header" style="width: 100%;"></div><a href="#" class="ui-slider-handle ui-state-default ui-corner-all" style="left: 0%;"></a></div>
<div class="ui-resizer-cols"></div>
<p> <a href="#" id="lnkResizer" style="float: right;">close</a>
</p>
</div>
1 ответ
Это было не так ясно (по крайней мере для меня) из документации, но исправление:
$("#ui-resizer").slider({
slide: function(e, ui) {
valfield.text(ui.value + "%");
$(column).attr("width", ui.value); //update col
}
});
Очевидно, что код, который я использовал (ниже), является глобальным для всех ползунков, использующих один обработчик, а приведенное выше исправление относится только к экземпляру ползунка? (если я правильно понял)
$("#ui-resizer").bind("slide", function(e, ui) { ... }