繁体   English   中英

Click事件触发两次,但仅在一种情况下触发

[英]Click event fires twice, but only in one case

还无法回答...

发现了问题...尝试了你们所说的所有内容,并逐一逐行地与Firebug进行了交互,我发现当我对带有javascript的div进行.empty()时,其中的所有js都会保留,因此每次刷新状态窗格时,我在堆栈中添加了另一组js。

必须更好地组织我的js ...谢谢大家。

//

我有一些jquery来处理控制面板类型系统上的点击。 点击共有三种点击,开/关(class =“ checkbox”),模式弹出窗口(class =“ editbox”)和模态执行。 “ checkbox”和“ editbox”可以正常工作,可以切换选项或显示弹出窗口,但是,如果hasClass('fl_ejecuta')如果匹配,则将其调用两次。

我已经遍历了多次代码,甚至将其与其他所有代码完全隔离开来,但是其中一个部分总是被调用两次……任何人都可以看到我错过的内容吗? 由于某种原因,我无法使它正常工作。

这是相关的javascript:

$(".conclick").click(function() {
    var accion = $(this).attr('accion');
    var data = $(this).attr('data');
    var valor = $(this).attr('valor');
    var esto = $(this);
    if($(this).hasClass('checkbox')) {
        $.post("ejecuta.php",{t:"checkbox",a:accion,d:data,v:valor}).done(function(retorno) {
            if(retorno != "N") {
                if(valor == "1") { esto.attr('valor','0'); esto.empty(); }
                if(valor == "0") { esto.attr('valor','1'); esto.empty().html('✓'); }
            } else {
                hayError("checkbox",accion,data,valor);
            }
        });
    }
    if($(this).hasClass('editbox')) {
        $.post("ejecuta.php",{t:"editbox",a:accion,d:data,v:valor}).done(function(retorno) {
            if(retorno.status == "OK") {
                $('.fl_titulo').empty().html(retorno.titulo);
                $('.fl_explica').empty().html(retorno.explica);
                $('.fl_data').empty().html(retorno.form);
                $('.fl_ejecuta').attr('data',retorno.data);
                $('#flotante').show('fast');
            } else {
                hayError("editbox",accion,data,valor);
            }
        }, "json");
    }
    if($(this).hasClass('fl_ejecuta')) {
        alert('fl_ejecuta');
    }
});

并触发两次点击的HTML:

    <div id="flotante" style="display:none;">
    <div id="flota">
        <div class="fl_titulo"></div><div id="fl_cerrar">X</div>
        <div class="fl_explica"></div>
        <div class="fl_data"></div>
        <div class="conclick fl_ejecuta" data="" valor=""><?php echo texto("MODIFICAR"); ?></div>
    </div>
</div>

您的代码

$(".conclick").click(function() {

似乎工作正常:

http://jsfiddle.net/kexwh/1/

尝试使用:

$(".conclick").live('click',function() { ....

您可能在js中两次附加了点击监听器。 或查看委派的.on。

发现了问题...尝试了你们所说的所有内容,并逐一逐行地与Firebug进行了交互,我发现当我对带有javascript的div进行.empty()时,其中的所有js都会保留,因此每次刷新状态窗格时,我在堆栈中添加了另一组js。

必须更好地组织我的js ...谢谢大家。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM