百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

JavaScript HTML DOM 事件之鼠标事件

zhezhongyun 2024-12-20 19:45 36 浏览

双份美女,双份快乐!好久没更新了。

上次我们介绍了JavaScript HTML DOM 事件的几个常见类别。今天我们详细介绍下鼠标相关的事件。

事件

描述

属于

on

mousedown

当用户在元素上按下鼠标按钮时,发生此事件。

MouseEvent

on

mouseenter

当指针移动到元素上时,发生此事件。

MouseEvent

on

mouseleave

当指针从元素上移出时,发生此事件。

MouseEvent

on

mousemove

当指针在元素上方移动时,发生此事件。

MouseEvent

on

mouseout

当用户将鼠标指针移出元素或其中的子元素时,发生此事件。

MouseEvent

on

mouseover

当指针移动到元素或其中的子元素上时,发生此事件。

MouseEvent

on

mouseup

当用户在元素上释放鼠标按钮时,发生此事件。

MouseEvent

on

click

当用户单击元素时发生此事件。

MouseEvent

on

contextmenu

当用户右键单击某个元素以打开上下文菜单时,发生此事件。

MouseEvent

on

dblclick

当用户双击元素时发生此事件。

MouseEvent


我们一个一个来介绍吧

  • onmousedown鼠标事件

当用户在元素上按下鼠标按钮时,发生此事件。

我们在网页上测试一下,我们点击id='header'的<div>节点试试看,让弹出按下鼠标的提示。代码如下

document.getElementById('header').onmousedown = function() {
    alert('鼠标按钮被按下!');
};

当我们在上图标红的框内点击鼠标(不论左键右键还是中键)时,就会弹出了按下鼠标的提示。

  • onmouseenter鼠标事件

当指针移动到元素上时,发生此事件。

我们还是以上面的位置进行测试吧,把鼠标移动到id='header'的<div>节点上,让弹出鼠标已到达战场。

document.getElementById('header').onmouseenter = function() {
    alert('鼠标已到达战场!');
};

测试结果没问题,鼠标移动到指定区域就会弹出提示。

  • onmouseleave鼠标事件

当指针从元素上移出时,发生此事件。

还是用id='header'的<div>节点来测试,当鼠标从节点移出时,弹出鼠标已离开战场的提示。

document.getElementById('header').onmouseleave= function() {
    alert('鼠标已离开战场!');
};

我们看到会有两个提示,一个是移入提示,一个是移出提示。


  • onmousemove鼠标事件

当指针在元素上方移动时,发生此事件。

我们换一个元素节点试试这个功能,我们选择id='js_appmsg_account'的<div>节点试试,在该节点上移动时,输出 在该节点上移动。我们看看效果

document.getElementById('js_appmsg_account').onmouseout= function() {
    console.log('鼠标在该节点上移动!');
};

我们在红框区域移动时,console界面就会不断输出 鼠标在该节点上移动的提示。

  • onmouseout鼠标事件

当用户将鼠标指针移出元素或其中的子元素时,发生此事件。

我们还是用id='js_appmsg_account'的<div>节点测试,移出时打印出移出该节点。


document.getElementById('js_appmsg_account').onmouseout= function() {
    console.log('鼠标移出该节点!');
};

可以看到,打印出的提示 显示了在该节点上移动后又移出的过程。

  • onmouseover鼠标事件

当指针移动到元素或其中的子元素上时,发生此事件。

我们还是id='js_appmsg_account'的<div>节点,当鼠标在这个节点上时,输出 鼠标在该节点上。我们看看效果。

document.getElementById('js_appmsg_account').onmouseover= function() {
    console.log('鼠标在该节点上!');
};

看看右下角打印出的提示,我们可以看到鼠标移入到该节点,然后在该节点上移动后又移出该节点的一整个移动过程。

  • onmouseup鼠标事件

当用户在元素上释放鼠标按钮时,发生此事件。

我们还是用id='js_appmsg_account'的<div>节点,我们没有设置在该节点按鼠标的操作,只设置释放鼠标按钮时,打印出 已松开鼠标按钮 的提示

document.getElementById('js_appmsg_account').onmouseup= function() {
    console.log('已松开鼠标按钮!');
};

可以看到鼠标移动到该节点然后在该节点上移动,松开鼠标按钮后移出该节点的动作。

  • onclick鼠标事件

当用户单击元素时发生此事件。

还是用上面的id='js_appmsg_account'的<div>节点,点击该节点 打印出 皮一下很开心

document.getElementById('js_appmsg_account').onclick= function() {
    console.log('皮一下很开心');
};

可以发现 鼠标的 onclick事件是在onmouseup事件发生之后执行的。我们再添加个onmousedown事件测试下看看看效果,如下图,按下按钮的onmousedown的事件先执行然后是onmouseup事件,最后是onclick事件。

  • oncontextmenu鼠标事件

当用户右键单击某个元素以打开上下文菜单时,发生此事件。

document.getElementById('js_appmsg_account').oncontextmenu= function() {
    console.log('右键菜单');
};

可以看到右键弹出菜单时 打印出了 右键菜单的提示。

  • ondblclick鼠标事件

当用户双击元素时发生此事件。

我们再试试双击按钮的功能。双击id='js_appmsg_account'的<div>节点时 打印出 双击了该节点 的提示。

document.getElementById('js_appmsg_account').ondblclick= function() {
    console.log('双击了该节点');
};

嗯,答应了 双击了该节点的提示。

好了 ,今天我们就大概介绍了一下JavaScript HTML DOM 鼠标事件的几个常用操作。下次我们再讲avaScript HTML DOM 键盘事件的常用操作。

相关推荐

JavaScript中常用数据类型,你知道几个?

本文首发自「慕课网」,想了解更多IT干货内容,程序员圈内热闻,欢迎关注!作者|慕课网精英讲师Lison这篇文章我们了解一下JavaScript中现有的八个数据类型,当然这并不是JavaScr...

踩坑:前端的z-index 之bug一二(zh1es前端)

IE6下浮动元素bug给IE6下的一个div设置元素样式,无论z-index设置多高都不起作用。这种情况发生的条件有三个:1.父标签position属性为relative;2.问题标签无posi...

两栏布局、左边定宽200px、右边自适应如何实现?

一、两栏布局(左定宽,右自动)1.float+margin即固定宽度元素设置float属性为left,自适应元素设置margin属性,margin-left应>=定宽元素宽度。举例:HTM...

前端代码需要这样优化才是一个标准的网站

  网站由前端和后端组成,前端呈现给用户。本文将告诉您前端页面代码的优化,当然仍然是基于seo优化的。  就前端而言,如果做伪静态处理,基本上是普通的html代码,正常情况下,这些页面内容是通过页面模...

网页设计如何自学(初学网页设计)

1在Dreamweaver中搭建不同的页面,需要掌握HTML的语句了,通过调整各项数值就可以制作出排版漂亮的页面,跟着就可以学习一些可视化设计软件。下面介绍网页设计如何自学,希望可以帮助到各位。Dre...

1、数值类型(数值类型有)

1.1数据类型概览MySQL的数据类型可划分为三大类别:数值类型:旨在存储数字(涵盖整型、浮点型、DECIMAL等)。字符串类型:主要用于存储文本(诸如CHAR、VARCHAR之类)。日期/...

网页设计的布局属性(网页设计的布局属性是什么)

布局属性是网站设计中必不可少的一个重要的环节,主要用来设置网页的元素的布局,主要有以下属性。1、float:该属性设置元素的浮动方式,可以取none,left和right等3个值,分别表示不浮动,浮在...

Grid网格布局一种更灵活、更强大的二维布局模型!

当涉及到网页布局时,display:flex;和display:grid;是两个常用的CSS属性,它们都允许创建不同类型的布局,但有着不同的用法和适用场景。使用flex布局的痛点当我们使...

React 项目实践——创建一个聊天机器人

作者:FredrikStrandOseberg转发链接:https://www.freecodecamp.org/news/how-to-build-a-chatbot-with-react/前言...

有趣的 CSS 数学函数(css公式)

前言之前一直在玩three.js,接触了很多数学函数,用它们创造过很多特效。于是我思考:能否在CSS中也用上这些数学函数,但发现CSS目前还没有,据说以后的新规范会纳入,估计也要等很久。然...

web开发之-前端css(5)(css前端设计)

显示控制一个元素的显示方式,我们可以使用display:block;display:inline-block;display:none;其中布局相关的还有两个很重要的属性:display:flex;和...

2024最新升级–前端内功修炼 5大主流布局系统进阶(分享)

获课:keyouit.xyz/14642/1.前端布局的重要性及发展历程前端布局是网页设计和开发的核心技能之一,它决定了页面元素如何组织和呈现。从早期的静态布局到现代的响应式布局,前端布局技术经历了...

教你轻松制作自动换行的CSS布局,轻松应对不同设备!

在网页设计中,自动换行的CSS布局是非常常见的需求,特别是在响应式设计中。它可以让网页内容自动适应不同屏幕尺寸,保证用户在不同设备上都能够获得良好的浏览体验。本文将介绍几种制作自动换行的CSS布局的方...

晨光微语!一道 CSS 面试题,伴你静享知识治愈时光

当第一缕阳光温柔地爬上窗台,窗外的鸟鸣声清脆悦耳,空气中弥漫着清新的气息。在这宁静美好的清晨与上午时光,泡一杯热气腾腾的咖啡,找一个舒适的角落坐下。前端的小伙伴们,先把工作的疲惫和面试的焦虑放在一边,...

2023 年的响应式设计指南(什么是响应式设计优缺点)

大家好,我是Echa。如今,当大家考虑构建流畅的布局时,没有再写固定宽度和高度数值了。相反,小编今天构建的布局需要适用于几乎任何尺寸的设备。是不是不可思议,小编仍然看到网站遵循自适应设计模式,其中它有...