JavaScript-筑基(十四)禁止鼠标右键、选中文字、获取鼠标坐标
2022/1/14 17:08:07
本文主要是介绍JavaScript-筑基(十四)禁止鼠标右键、选中文字、获取鼠标坐标,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
-
禁止鼠标右键菜单 contextmenu主要控制应该何时显示上下文菜单,主要用于程序员取消默认的上下菜单
-
禁止鼠标选中(selectstart开始选中)
// 1. contextmenu 我们可以禁用右键菜单 document.addEventListener('contextmenu', function(e) { e.preventDefault(); }) // 2. 禁止选中文字 selectstart document.addEventListener('selectstart', function(e) { e.preventDefault(); })
鼠标事件对象
event对象代表事件的状态,跟事件相关的一系列信息的集合。现阶主要是用鼠标事件对象MouseEvent和键盘事件对象KeyBoardEvent。
e.clientX | 返回鼠标相对游览器窗口可视区的X坐标 |
e.clientY | 返回鼠标相对游览器窗口可视区的Y坐标 |
e.pageX | 返回鼠标相对文档页面的X坐标 |
e.pageY | 返回鼠标相对文档页面的Y坐标 |
e.screenX | 返回鼠标相对电脑屏幕的X坐标 |
e.scY | 返回鼠标相对电脑屏幕的Y坐标 |
<script> // 鼠标事件对象 MouseEvent document.addEventListener('click', function(e) { // 1. client 鼠标在可视区的x和y坐标 console.log(e.clientX); console.log(e.clientY); console.log('---------------------'); // 2. page 鼠标在页面文档的x和y坐标 console.log(e.pageX); console.log(e.pageY); console.log('---------------------'); // 3. screen 鼠标在电脑屏幕的x和y坐标 console.log(e.screenX); console.log(e.screenY); }) </script>
案例:跟随鼠标的天使
- 鼠标不断移动,使用鼠标移动事件:mousemove
- 在页面中移动,给document注册事件
- 图片要移动距离,而且不占位置,使用绝对定位
- 核心原理:每次鼠标移动,获得最新鼠标坐标,把这个坐标作为图片的top和left值。
<style> img { position: absolute; } </style> </head> <body> <img src="images/angel.gif" alt=""> <script> var pic = document.querySelector('img'); document.addEventListener('mousemove', function(e) { // 1. mousemove只要我们鼠标移动1px 就会触发这个事件 // 2.核心原理: 每次鼠标移动,我们都会获得最新的鼠标坐标, 把这个x和y坐标做为图片的top和left 值就可以移动图片 var x = e.pageX; var y = e.pageY; console.log('x坐标是' + x, 'y坐标是' + y); //3 . 千万不要忘记给left 和top 添加px 单位 pic.style.left = x - 50 + 'px';//-50是为了让鼠标居于图片中间 pic.style.top = y - 40 + 'px'; }); </script> </body>
当作商品图片局部放大时,会用到鼠标跟随
学习快乐!
这篇关于JavaScript-筑基(十四)禁止鼠标右键、选中文字、获取鼠标坐标的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-12百万架构师第十五课:源码分析:Spring 源码分析:SpringMVC核心原理及源码分析|JavaGuide
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide