javascript - jQuery插件,只绑定(bind)一次事件

标签 javascript jquery events triggers bind

我正在构建一个灯箱 jQuery 插件,但遇到了一个问题,即事件触发的频率与我在同一页面上有灯箱的频率一样。也许您知道如何防止这种情况发生。这是示例代码。

;( function( $, window, document, undefined ){
'use strict';

$.fn.myPlugin = function( options ){

    // here are some functions for click and touching   
    $(document).on('click', '.elem', function(e){
        e.preventDefault();
        console.log('click');
    });

    $( document ).on( 'touchstart','.elem', function(e){
        console.log('touch');
    });

    return this;
};
})( jQuery, window, document );

因此,如果我现在像我想使用的那样频繁地调用我的插件:

$('.elem1').myPlugin();
...
$('.elem4').myPlugin();

当我调用插件时,点击或触摸 console.log 就会触发。您对如何修复它有什么建议吗?

这是当前正在运行的插件,一页上有 4 个画廊。 http://andreknieriem.de/simple-lightbox-dev/

最佳答案

您的 onClick 为类为 .elem 的每个元素调用该函数。另外,当您执行 $(document).on('click'... 时,您正在监听页面上任意位置的点击。我猜这不是您想要的行为?你的意思是 $(this).on('click' ...?

尝试如下:

$.fn.myPlugin = function( options ){
    var target = this;

    // here are some functions for click and touching   
    $(document).on('click', target, function(e){
        e.preventDefault();
        console.log('click');
    });

    ... 

关于javascript - jQuery插件,只绑定(bind)一次事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35488556/

相关文章:

javascript - React - 映射要返回的组件数组

javascript - ajax调用成功后重新初始化Slick js

未定义 Javascript onload 函数

javascript - 动态添加完整日历不起作用

javascript - jQuery 选择数据属性并隐藏

javascript - 如何获取输入值,然后根据索引 0 处的所有数组对象值检查该值

javascript - 如何在复选框单击时停止事件冒泡

javascript - 在没有特定目标的情况下触发JavaScript中的全局触摸/点击事件

javascript - 使用 'window' 、 'document' 和 'undefined' 作为包装 jQuery 插件的匿名函数中的参数

javascript - 将枚举对象转换为数组在 javascript 中返回额外的对象