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

JavaScript HTML DOM 事件之鼠标事件

myzbx 2025-01-10 15:40 47 浏览

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

上次我们介绍了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 键盘事件的常用操作。

相关推荐

如何设计一个优秀的电子商务产品详情页

加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

怎么在JS中使用Ajax进行异步请求?

大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

前端监控 SDK 开发分享_前端监控系统 开源

一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

Ajax 会被 fetch 取代吗?Axios 怎么办?

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

前端面试题《AJAX》_前端面试ajax考点汇总

1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

Ajax 详细介绍_ajax

1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

6款可替代dreamweaver的工具_替代powerdesigner的工具

dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

福斯《死侍》发布新剧照 &quot;小贱贱&quot;韦德被改造前造型曝光

时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

2021年超详细的java学习路线总结—纯干货分享

本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

2025 年 Python 爬虫四大前沿技术:从异步到 AI

作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

最贱超级英雄《死侍》来了!_死侍超燃

死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

停止javascript的ajax请求,取消axios请求,取消reactfetch请求

一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...