如何在自定义帮助器中重新实现 jQuery 的默认帮助器

Posted

技术标签:

【中文标题】如何在自定义帮助器中重新实现 jQuery 的默认帮助器【英文标题】:How to reimplement jQuery's default helper in a custom helper 【发布时间】:2010-09-16 05:26:38 【问题描述】:

我正在创建一个自定义拖动助手(在 jQuery 中):

$('.dragme', element).draggable(
    appendTo: 'body',
    helper  : custom_drag_helper,
    opacity : 0.5
);

我这样做是因为我想有时克隆,有时执行默认功能,即拖动原始元素。

function custom_drag_helper() 
    if (/*criteria on when to move instead of clone */) 
        return $(this); /* this is what helper: 'original' seems to do */
     else 
        clone = $(this).clone(); /* this is what helper: 'clone' does */
        return clone;
    

但我根本无法使用原始功能。 return clone() 工作正常,但 return $(this) 没有任何乐趣。

【问题讨论】:

【参考方案1】:

好的,当我输入这个问题时,我做了更多的来源潜水,发现了这条小线:

if (this.options.helper == 'original' && !(/^(?:r|a|f)/).test(this.element.css("position")))
        this.element[0].style.position = 'relative';

在我试图解决这个问题的那天我没有找到。在我上面的代码中添加this.style.position = 'relative'; 解决了这个问题!

【讨论】:

以上是关于如何在自定义帮助器中重新实现 jQuery 的默认帮助器的主要内容,如果未能解决你的问题,请参考以下文章

jQuery .click() 在自定义函数之前执行默认动作

重新实现 QStyledItemDelegate::paint - 如何获取子元素坐标?

从 SVF 更新到 SVF2 后,法线在自定义着色器中中断

在自定义布局管理器中使用SectionList组件

ag-grid:水平向后和向前滚动后,在自定义单元格渲染器中发现服务未定义

如何让其他控件在自定义控件中看到 DataTables 的集合?