前端学习-事件解绑,mouseover和mouseenter的区别(二十九)

目录

前言

解绑事件

语法

鼠标经过事件的区别

鼠标经过事件

示例代码

两种注册事件的区别

总结



前言

人道洛阳花似锦,偏我来时不逢春

解绑事件

on事件方式,直接使用null覆盖就可以实现事件的解绑

语法

javascript 复制代码
btn.onclick = function(){
    alert('点击了')
}
btn.onclick = null;

 const ben = document.querySelector('button');
    ben.addEventListener('click', function fn() {
      console.log('click');
    })
    ben.removeEventListener('click', fn);

注意:匿名函数无法被解绑

鼠标经过事件的区别

鼠标经过事件

mouseover和mouseout会有冒泡效果

mouseenter和mouseleave没有冒泡效果(推荐)

示例代码

javascript 复制代码
<!DOCTYPE html>
<html lang="en">
​
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .dad {
      width: 200px;
      height: 200px;
      background-color: red;
    }
​
    .son {
      width: 100px;
      height: 100px;
      background-color: blue;
    }
  </style>
</head>
​
<body>
  <button id="myButton">点击</button>
  <div class="dad">
    <div class="son"></div>
  </div>
  <script>
    const ben = document.querySelector('#myButton');
    const dad = document.querySelector('.dad');
    const son = document.querySelector('.son');
​
    // 定义命名函数
    function handleClick() {
      console.log('click');
    }
​
    function handleMouseOver() {
      console.log('over');
    }
​
    function handleMouseOut() {
      console.log('out');
    }
​
    // 添加事件监听器
    ben.addEventListener('click', handleClick);
    dad.addEventListener('mouseenter', handleMouseOver);
    dad.addEventListener('mouseleave', handleMouseOut);
​
    // 示例:在按钮点击后移除事件监听器
    ben.addEventListener('click', function () {
      ben.removeEventListener('click', handleClick);
      dad.removeEventListener('mouseenter', handleMouseOver);
      dad.removeEventListener('mouseleave', handleMouseOut);
      console.log('事件已解绑');
    });
  </script>
</body>
​
</html>

两种注册事件的区别

传统on注册(L0)

同一个对象,后面注册的事件会覆盖前面注册(同一个事件)

直接使用null覆盖就可以实现事件的解绑

都是冒泡阶段执行的事件

监听注册(L2)

语法: addEventListener(事件类型,事件处理函数,是否使用捕获)

后面注册的事件不会覆盖前面注册的事件(同一个事件)

可以通过第三个参数去确定是在冒泡或者捕获阶段执行必须使用removeEventListener(事件类型,事件处理函数,获取捕获或者冒泡阶段)

匿名函数无法被解绑


总结

春风得意马蹄疾,一日观尽长安花

相关推荐
im_AMBER15 分钟前
学习日志19 python
python·学习
灵感__idea2 小时前
JavaScript高级程序设计(第5版):好的编程就是掌控感
前端·javascript·程序员
烛阴3 小时前
Mix
前端·webgl
代码续发4 小时前
前端组件梳理
前端
试图让你心动4 小时前
原生input添加删除图标类似vue里面移入显示删除[jquery]
前端·vue.js·jquery
_Kayo_4 小时前
VUE2 学习笔记6 vue数据监测原理
vue.js·笔记·学习
chenchihwen5 小时前
大模型应用班-第2课 DeepSeek使用与提示词工程课程重点 学习ollama 安装 用deepseek-r1:1.5b 分析PDF 内容
人工智能·学习
陈不知代码5 小时前
uniapp创建vue3+ts+pinia+sass项目
前端·uni-app·sass
小王码农记5 小时前
sass中@mixin与 @include
前端·sass
陈琦鹏5 小时前
轻松管理 WebSocket 连接!easy-websocket-client
前端·vue.js·websocket