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

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

160 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页面的脚本语言而出名,但是它也被用到了很多非浏览器环境中。

推荐前端开发开发教程
JavaScript过滤XSS攻击方法
JavaScript过滤XSS攻击方法

什么是XSS?XSS(Cross Site Scripting),跨站脚本攻击,是一种允许攻击者在另外一个...

1 467
jQuery怎样监听鼠标滚动是向上还是向下的状态?
jQuery怎样监听鼠标滚动是向上还是向下的状态?

知乎鼠标向下滚动显示文章标题,向上滚动显示栏目;又或者向下滚动到底部时异步...

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

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

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

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

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

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

1 496
swiper轮播图空白案例记录
swiper轮播图空白案例记录

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

0 443
jQuery监听点击事件弹出关注二维码教程
jQuery监听点击事件弹出关注二维码教程

通过jQuery实现点击关注按钮弹出二维码是一个比较常用的功能,今天鸥哥讲讲这...

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

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

0 1776
推荐插件
帝国cms纳米数据接口(足球比赛中最新数据)
帝国cms纳米数据接口(足球比赛中最新数据)

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

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

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

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

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

0 665
帝国cms访问统计ip地址链接与封禁插件下载
帝国cms访问统计ip地址链接与封禁插件下载

下载鸥开发了这款帝国cms封禁ip插件,自动记录访问情况,让我们可以更快的识别...

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

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

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

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

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

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

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

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

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