是否可以通过拖放重新排序选项卡(请参阅此处的 Kendo Tabstrip 基本模式)?类似于在 Excel 中拖动选项卡。
问问题
792 次
1 回答
3
在kendo 论坛上有一个与此类似的已解决问题,它已经有了解决此问题的答案,方法是扩展kendo tabstrip 小部件并将kendo Reorderable添加到其中。
var numTabs = 1, tabs = null;
var reorderableTabStrip = kendo.ui.TabStrip.extend({
options: {
name: 'ReorderableTabStrip'
},
init: function ( element, options ) {
kendo.ui.TabStrip.fn.init.call(this, element, options);
this.applyReorderable();
},
applyReorderable: function () {
var reorderable = this.tabGroup.data('kendoReorderable');
if ( reorderable ) {
reorderable.destroy();
}
this.tabGroup.kendoReorderable({
group: 'tabs',
filter:'.k-item',
hint: function(element) {
return element.clone().wrap('<ul class="k-tabstrip-items k-reset"/>').parent().css({opacity: 0.8});
},
change: $.proxy(this.onReorderableChange, this)
});
},
onReorderableChange: function ( event ) {
if ( event.newIndex < event.oldIndex ) {
this.tabGroup.children('.k-item:eq('+event.newIndex+')').before( this.tabGroup.children('.k-item:eq('+event.oldIndex+')') );
this.element.children('.k-content:eq('+event.newIndex+')').before( this.element.children('.k-content:eq('+event.oldIndex+')') );
}
else {
this.tabGroup.children('.k-item:eq('+event.newIndex+')').after( this.tabGroup.children('.k-item:eq('+event.oldIndex+')') );
this.element.children('.k-content:eq('+event.newIndex+')').after( this.element.children('.k-content:eq('+event.oldIndex+')') );
}
this._updateClasses();
}
});
kendo.ui.plugin( reorderableTabStrip );
tabs = $('#tabs').kendoReorderableTabStrip().data('kendoReorderableTabStrip');
$('#button').click( onButtonClick );
function onButtonClick () {
numTabs++;
tabs.append({
text: 'Tab ' + numTabs,
content: 'Tab ' + numTabs + ' Content'
});
tabs.applyReorderable();
}
我按照那里的答案并由提出问题的人修改jsfiddle,它工作正常。
于 2015-06-16T01:01:16.753 回答