下载鸥 > 网站下载 > 开发教程 > JS/JQuery

为什么jQuery的click事件会触发两次?

101 2024-06-06 01:13:41

收藏
为什么jQuery的click事件会触发两次?
今天有客户找鸥哥排查一个bug,说click事件触发了两次,源码如下。
 

html代码

<div class="form-checkbox rememberbox">
    <input type="checkbox" id="remember-me" class="form-checkbox-input" value="">
    <label id="remember-me" class="form-label">
        <span class="checkbox" aria-hidden="true"></span> 记住我
    </label>
</div>
 

带bug的js代码

$(".rememberbox").click(function(){
    console.log('clicked');
    if($(this).hasClass("active")){
        $(this).removeClass("active");
        $("#remember-me").val("");
    }else{
        $(this).addClass("active");
        $("#remember-me").val("1");
    }
})

每次点击,都打印了两次clicked。

那么,这是什么原因呢?
 

原因分析

如果点击事件处理器被绑定了包含 <input type="checkbox"> 和 <label> 的容器元素,这一般就是 <label> 与其关联的 <input> 之间的默认行为导致的。

在HTML中,点击与 <input> 关联的 <label> 会自动触发 <input> 的点击事件。因此,如果点击事件处理器同时绑定在包含这两者的父元素上,那么点击 <label> 可能会导致处理器被触发两次:

一次是因为直接点击了 <label>,另一次是因为 <label> 触发了关联的 <input> 的点击事件,而这个事件又冒泡到了父元素。

解决方案也很简单,绑定的点击事件换到label上就好了
 

优化后的js

$("#remember-me-label").click(function(){
    console.log('clicked');
    event.stopPropagation();
    if($(this).parent(".rememberbox").hasClass("active")){
        $(this).parent(".rememberbox").removeClass("active");
        $("#remember-me").val("");
    }else{
        $(this).parent(".rememberbox").addClass("active");
        $("#remember-me").val("1");
    }
})

本文地址:https://xzo.com.cn/develop/js/1235.html

有帮助,很赞!

信息来源:下载鸥
导出教程 下载word版教程
发表评论 共有条评论
关于JS/JQuery


JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式和声明式(如函数式编程)风格。

JavaScript十分强大,不管是前端页面开发、视觉动态渲染、数据交互还是后端逻辑处理,都可以通过JS实现。虽然它是作为开发Web页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐JS/JQuery开发教程
通过原生的JS实现点击复制效果
通过原生的JS实现点击复制效果

对于网站、app开发等工作而言,复制是一个非常常见的功能。很多人到处找插件...

1 420
JS验证手机是否11位的做法
JS验证手机是否11位的做法

在网站表单提交前,我们往往需要验证一下信息避免错误数据,那么,怎样验证手机号...

1 432
jquery怎样获取textarea用户输入的行数?
jquery怎样获取textarea用户输入的行数?

jQuery是一个相当好用的js插件,通过jquery我们可以实现很多功能,例如今天要介...

0 556
怎样点击清除ul里的全部li信息?
怎样点击清除ul里的全部li信息?

在通过jQuery做数据交互时我们可能存在这样的需求:通过点击按钮清空ul里的li...

1 531
$(window).height() 和 $(document).height()有什么不同?
$(window).height() 和 $(document).height()有什么不同?

我们常用$(window).height() 和 $(document).height()来监听当前高度,但这个...

1 402
JS点击复制data-*属性(支持多个元素)
JS点击复制data-*属性(支持多个元素)

分享一段js原生点击复制data-*属性的源码,根据onclick事件触发,复制当前元素...

0 409
swiper轮播图空白案例记录
swiper轮播图空白案例记录

今天鸥哥在用swiper做轮播图时,轮播效果虽然没问题,但只显示第一张,后面的图片...

0 402
js判断windows操作系统还是mac os系统
js判断windows操作系统还是mac os系统

网站日常访客主要是windows和mac os两种操作系统,如果网站提供资源下载,则需...

0 1873
推荐插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件
帝国cms智能自动审核按星期几审核指定栏目带推送插件

采集站的必备资源是自动审核,要做到日收录也离不开定时发布。而本插件的自动...

0 1274
帝国cms联想词搜索高级搜索插件下载
帝国cms联想词搜索高级搜索插件下载

帝国CMS自带的搜索功能虽然强大,但也有很强的局限性 -- 必须关键词完全匹配...

0 736
帝国cms在线考试系统模板插件
帝国cms在线考试系统模板插件

一直没看到好用的帝国cms在线考试插件,所以自己开发了一款。在线考试插件用...

0 1258
帝国cms百度AI图像清晰度增强api接口对接插件
帝国cms百度AI图像清晰度增强api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像清晰度增强的功能。经...

0 498
帝国cms百度AI图像去雾api接口对接插件
帝国cms百度AI图像去雾api接口对接插件

通过本插件,可以实现帝国cms网站对接百度云api实现图像去雾的功能。经过实际...

0 449
帝国cms批量添加后台用户插件
帝国cms批量添加后台用户插件

使用帝国cms的企业用户、新闻资讯类站点的用户很多,此类站点很多时候需要有...

0 676
帝国CMS内网用户静态站点文章访客统计插件
帝国CMS内网用户静态站点文章访客统计插件

本插件适用于内网用户,可查看单篇文章访问者ip地址。如果添加访问者ip组,可查...

0 537
帝国cms自动给正文关键词添加tag内链
帝国cms自动给正文关键词添加tag内链

帝国cms有自带的给关键词添加内链功能,但需要手动添加关键词,容易出现疏漏和...

0 811
客服QQ:341553759
扫码咨询 常见问题 >
官方交流群:90432500
点击加入