使用jQuery UI Draggable,使用滚动条时如何避免拖动?
很久以前,我在我的应用程序中创建了一个对话框.对话框非常简单,绝对定位,通过 javascript 在屏幕中居中.
A long time ago I created a dialog box in my application. The dialog is pretty simple, position absolute, centered in the screen via javascript.
现在我已将 jQuery UI 添加到应用程序中,但我不想仅仅因为它们的工作方式不同而使用 jQuery UI 的对话框.但我确实使用 jQuery UI 使我的对话框可拖动,因为它非常简单:
Now I have added jQuery UI to the application but I do not want to use jQuery UI's dialogs just because they work differently. But I did make my dialog draggable using jQuery UI as it is very easy:
$('#dialog').draggable();
有一个问题,我的一些对话框有滚动条.
但是使用 draggable 方法,如果有滚动条,它会因为拖动对话框而出错.
There is one problem with that, some of my dialogs have scrollbars.
But using the draggable method, if there is a scrollbar, it bugs because it drags the dialog.
有没有办法让对话框在使用滚动条时不拖动?
我注意到有一些方法可以避免元素被拖动,但滚动条不是元素.
Is there a way for the dialog to not drag while using the scrollbar ?
I noticed there are some ways to avoid elements to be dragged, but scrollbars are not elements.
谢谢
JSFiddle:http://jsfiddle.net/FGXnR/
推荐答案
作为一种解决方法,您可以尝试使用 handle
选项 并且只使对话框可以被不可滚动的部分拖动.(标题之类的.)
As a workaround, you could try using the handle
option and only make the dialog draggable by the parts that aren't scrollable. (The title or some such.)
@AlexFigueiredo 指出的另一个解决方案仅涉及 将内容/句柄包装在 div
处理大小调整和滚动——这似乎阻止了点击事件被发送到句柄.
Another solution that @AlexFigueiredo pointed out involves just wrapping the content / handle in a div
that handles the sizing and scrolling – that seems stop the click event from being sent to the handle.
相关文章