JQuery UI可选插件:当div溢出时,滚动条不可选

时间:2010-02-25 00:35:41

标签: jquery jquery-ui

我有一个设为overflow: auto;的div。这个div的内容是可选择的(使用jQuery UI)。

当div溢出并出现滚动条时,滚动条本身变得可选,因此滚动效果不佳。在FF / Chrome中,我可以滚动div但是我得到了可选择的轮廓。在Safari中,滚动条根本不会参与,因为可选择的处理程序会选择点击。

我可以使用选择器将滚动条添加到“取消”项目列表中吗?或者是否有其他方法可以防止滚动条被选择?

以下是我如何配置可选div的代码片段:

$(".mySelectable").selectable( {
    cancel: '.myButton, .notSelectable',
    filter: '.rowSelectable',
    selecting: function(event, ui){
        handleSelection(ui.selecting);
    },
    selected: function(event, ui) {
        handleSelected(ui.selected);
    },
    unselected: function(event, ui) {
        handleUnselected(ui.unselected);
    }
});

我的HTML看起来像:

<div class="mySelectable"> <!-- set to auto overflow -->
    <div class="myButton">I can't be selected</div>
    <div class="rowSelectable">I am a selectable row</div>
    ...
</div>

理想情况下,我正在寻找可以添加到“取消”选项的内容,这有助于跳过滚动条。

1 个答案:

答案 0 :(得分:15)

D'哦!解决方案很简单 - 添加另一个div而不是它的溢出设置。 所以,html变成了:

    <div class="wrapperDiv"> <!-- set to auto overflow -->
        <div class="mySelectable"> <!-- NOT set to overflow -->
            <div class="myButton">I can't be selected</div>
            <div class="rowSelectable">I am a selectable row</div>
            ...
        </div>
    </div>