Kendo 列表框工具栏在移动视图中滚出屏幕

Kendo listbox toolbar scrolls off screen in mobile view

我有一个 Kendo 列表框,其工具栏允许排序 (up/down) 和删除列表项。当我的列表框有足够的项目使其超出移动设备的视图时,向下滚动会导致工具栏滚出屏幕。因此,如果用户想要向上移动列表框的底部项目,他们必须向下滚动,select 项目,然后向上滚动以访问工具栏操作,这会导致糟糕的用户体验。如何使工具栏随列表一起滚动,甚至只是复制列表底部的工具栏?

这是我的小部件定义:

$("#myMenus").kendoListBox({
    selectable: "multiple",
    toolbar: {
        scrollable: true,
        tools: [ "moveUp", "moveDown", "remove" ]
    },
    reorder: function(e) {
        e.preventDefault();
        var UID = $(e.items[0]).attr("data-uid");
        var dataSource = e.sender.dataSource;
        var dataItem = e.dataItems[0]
        var index = dataSource.indexOf(dataItem) + e.offset;
        dataSource.remove(dataItem);
        dataSource.insert(index, dataItem);
        e.sender.wrapper.find("[data-uid='"+UID+"']").addClass("k-state-selected");
    },
});

我能够使用 CSS 修复工具栏的位置。如果您的 listBox 将使用非固定高度,这是必需的,在我的例子中,我需要使用 "height:100%" 以便 listBox 的大小等于内容。您需要根据自己的情况调整 width 和 margin-left 值。

<style>
    .k-listbox {
        width: 275px;
        height: 100%;
      }


  .k-listbox-toolbar {
    top:10;
    position:fixed;
    width:auto;
    z-index: 1;
    margin-left: 42px !important;
  }
</style>