下载鸥 > 网站下载 > 开发教程 > 前端开发

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

72 2024-06-06 01:13:41

收藏
今天有客户找鸥哥排查一个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版教程
发表评论 共有条评论
关于前端开发


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

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

推荐前端开发开发教程
怎样点击清除ul里的全部li信息?
怎样点击清除ul里的全部li信息?

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

1 466
Superslide响应式页面直接应用手机端技巧介绍
Superslide响应式页面直接应用手机端技巧介绍

如果是响应式网站,那么用superslide做轮播图需要做两个,这无疑是非常不方便的...

1 437
JS获取当前时间、日期、星期并每秒更新一次
JS获取当前时间、日期、星期并每秒更新一次

很多网站上会有当前年月日、星期、时间的展示。这个展示用php做未免浪费性...

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

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

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

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

0 358
js网站视频播放器ckplayer和dplayer优缺点分析
js网站视频播放器ckplayer和dplayer优缺点分析

dplayer和ckplayer都是非常流行的web视频播放器,二者都占有相当大的用户市场...

0 1549
JS判断苹果iPhone与iPad、安卓设备类型适配
JS判断苹果iPhone与iPad、安卓设备类型适配

在网站开发的过程中,一些涉及到资源下载的网站会通过判断不同系统手机来展示...

3 639
JS获取浏览器语言(中英文多语言站)并自动跳转代码
JS获取浏览器语言(中英文多语言站)并自动跳转代码

如果是多语言站点,主动获取浏览器默认语言并自动进行跳转可以有效降低跳出率...

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

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

0 520
帝国cms百度AI黑白图像上色api接口对接插件
帝国cms百度AI黑白图像上色api接口对接插件

百度开放了系列AI功能api如图像上色、图像去雾、图像修复、无损放大、清晰...

0 386
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

帝国cms 对接纳米数据(www.nami.com)接口,本接口主要接收、整理足球比赛实时数...

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

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

0 1249
帝国cms百度AI图像无损放大api接口对接插件
帝国cms百度AI图像无损放大api接口对接插件

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

0 410
帝国cms多栏目多数据表自动审核推送插件
帝国cms多栏目多数据表自动审核推送插件

本插件基于帝国cms帝国cms每日自动审核插件,在自动审核指定条数信息的基础上...

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

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

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

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

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