jQuery 在事件之间传递 var

标签 jquery events mouseevent

我尝试了解如何在 jQuery 事件之间传递 DOM。

例如,我创建了一个简单的工具提示插件,它附加在 mouseenter 上一个 div,我想在 mouleave 上删除相同附加的 div。但是,如果我有多个悬停元素,我无法选择要删除的正确元素。

这里是一个简单的示例代码:

    $(this).on('mouseenter', function() {

        $('<div class="'+options.class.split('.').join('')+'"></div>').appendTo('body').addClass(options.hoverClass.split('.').join(''));
        $tooltip = $(document).find(options.class).last();

    }).on('mouseleave', function() {

        $tooltip.first().removeClass(options.hoverClass.split('.').join(''));
        setTimeout(function() {
            $tooltip.first().remove(); // remove the right DOM appended for the element hovered
        },400);

    });

原代码:http://fiddle.jshell.net/Lw4behcu/1/

编辑:工作 fiddle :http://fiddle.jshell.net/Lw4behcu/2/

最佳答案

您可以使用data()方法来存储相关的工具提示:

$(this).on('mouseenter', function () {
    var $tooltip = $('<div class="' + options.class.split('.').join('') + '"></div>').appendTo('body').addClass(options.hoverClass.split('.').join(''));
    $(this).data('tooltip', $tooltip);


}).on('mouseleave', function () {
    var $tooltip = $(this).data('tooltip').removeClass(options.hoverClass.split('.').join(''));
    setTimeout(function () {
        $tooltip.remove(); // remove the right DOM appended for the element hovered
    }, 400);

});

关于jQuery 在事件之间传递 var,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31456883/

相关文章:

javascript - 如何使用代码将js部分代码包含到另一个js文件中。 [准备工作]

JavaScript 阻止触摸在 body 元素上移动,在其他元素上启用

javascript - 获取 Canvas 内的鼠标位置

java - DatePicker 上的事件过滤器针对一个操作触发两次

javascript - javascript中如何判断鼠标指针是否越过某个元素

java - 为 JToolBar 添加 MouseListeners(事件被消耗?)

javascript - 如何在 JQuery/Javascript 中验证表单

jquery - 从主提交表单

jquery - 在 jQuery 中获取 var 的值

javascript - Electronjs 检测窗口变化