jq: 事件-鼠标

2024-08-20 16:48
文章标签 事件 鼠标 jq

本文主要是介绍jq: 事件-鼠标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点击

在js中,绑定事件函数要具体到元素,如

        <ul><li>1</li><li>2</li>
</ul>
<script>var li0 = document.getElementsByTagName('li')[0];li0.onclick = function() {console.log(this.innerText)}
</script>

v2-3fa4050fa7fd84d8fd8465d6b877cffe_b.jpg



所以在jq中同理,可以利用this,点击谁,获取谁的元素,再放入到jq对象即可使用对应的方法,如:

        <ul><li>1</li><li>2</li>
</ul>
<script src="../jquery-3.4.1.js"></script>
<script>$('li').click(function() {console.log($(this).text());})
</script>

v2-3f5681f2c567f3ed59738fa07483a02d_b.gif



事件函数中的event参数

event.pageX 获取浏览器到当前的x轴位置

event.pageY 获取浏览器到当前的y轴位置

        $('.item').click(function(e) {console.log(`x轴位置:${e.pageX} y轴位置:${e.pageY} `);
})

v2-2e1fe53805e7688f04076c0f73b77f1c_b.jpg


event.which 判断点击的左键 中键 右键

event.which = 1 鼠标左键

event.which = 2 鼠标中键

event.which = 3 鼠标右键

contextmenu = false 函数可以取消右键菜单弹出

        $(document).contextmenu(function() { // 防止右键菜单弹出
    return false;
})$(document).mousedown(function(e) {console.log(e.which);
})





click 单机事件

dblclick 双击事件


移动

mouseenter/mouseleave 鼠标进入/鼠标离开

        $('.item').mouseenter(function() {console.log('鼠标移入')
}).mouseleave(function() {console.log('鼠标移出')
})

v2-0cba8e500072964d609f7204b1b9dfe2_b.gif

是否冒泡: 不冒泡

        $('.item').mouseenter(function() {console.log('item鼠标移入')
}).mouseleave(function() {console.log('item鼠标移出')
})$('.box').mouseenter(function() {console.log('box鼠标移入')
}).mouseleave(function() {console.log('box鼠标移出')
})

v2-b3ecaee2c025bbdd1fa41aa10dd61aa4_b.gif



mouseover/mouseout 鼠标进入/鼠标离开(会冒泡)

        $('.item').mouseover(function() {console.log('item鼠标移入')
}).mouseout(function() {console.log('item鼠标移出')
})$('.box').mouseover(function() {console.log('box鼠标移入')
}).mouseout(function() {console.log('box鼠标移出')
})

v2-4c2513d68fa2e55f980efd8ca80e1e3d_b.gif

v2-19fa561590de35c0ca96cc77e51004f7_b.gif

鼠标进入item中,触发冒泡,box的进入事件函数也被调用。

鼠标离开item中,触发冒泡,box的离开事件也被调用,然后进入到了box区域中(因为依然还在这里)。


mousedown 鼠标按下

mouseup 鼠标抬起

拖拽:

        <style>.item {position: relative;width: 100px;height: 100px;background: orange;}
</style>
</head>
<body>
<div class="item">test</div>
<script src="../jquery-3.4.1.js"></script>
<script>$('.item').mousedown(function(e) {var offset = $(this).offset();  // 定义盒子的边框
      var dis = {};                   // 创建一个存放鼠标到盒子边框的位置
      dis.x = e.pageX - offset.left;  // 鼠标到盒子左边距离
      dis.y = e.pageY - offset.top;   // 鼠标到盒子右边距离
      var _this = this;               // 盒子的this
      $(document).mousemove(function(e) {$(_this).css({              // 盒子的样式
                left: e.pageX - dis.x, // 移动到新位置 - 鼠标到盒子的距离 = 盒子定位的位置
                top: e.pageY - dis.y,})}).mouseup(function() {         // 鼠标抬起后
      $(this).off('mousemove mouseup') // 取消移动和抬起事件
            })return false; // 防止文字被选中
        })</script>

v2-29437f5132596683763ef017543ea350_b.gif

这篇关于jq: 事件-鼠标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1090630

相关文章

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

spring @EventListener 事件与监听的示例详解

《spring@EventListener事件与监听的示例详解》本文介绍了自定义Spring事件和监听器的方法,包括如何发布事件、监听事件以及如何处理异步事件,通过示例代码和日志,展示了事件的顺序... 目录1、自定义Application Event2、自定义监听3、测试4、源代码5、其他5.1 顺序执行

Python中的异步:async 和 await以及操作中的事件循环、回调和异常

《Python中的异步:async和await以及操作中的事件循环、回调和异常》在现代编程中,异步操作在处理I/O密集型任务时,可以显著提高程序的性能和响应速度,Python提供了asyn... 目录引言什么是异步操作?python 中的异步编程基础async 和 await 关键字asyncio 模块理论

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new

韦季李输入法_输入法和鼠标的深度融合

在数字化输入的新纪元,传统键盘输入方式正悄然进化。以往,面对实体键盘,我们常需目光游离于屏幕与键盘之间,以确认指尖下的精准位置。而屏幕键盘虽直观可见,却常因占据屏幕空间,迫使我们在操作与视野间做出妥协,频繁调整布局以兼顾输入与界面浏览。 幸而,韦季李输入法的横空出世,彻底颠覆了这一现状。它不仅对输入界面进行了革命性的重构,更巧妙地将鼠标这一传统外设融入其中,开创了一种前所未有的交互体验。 想象

FreeRTOS内部机制学习03(事件组内部机制)

文章目录 事件组使用的场景事件组的核心以及Set事件API做的事情事件组的特殊之处事件组为什么不关闭中断xEventGroupSetBitsFromISR内部是怎么做的? 事件组使用的场景 学校组织秋游,组长在等待: 张三:我到了 李四:我到了 王五:我到了 组长说:好,大家都到齐了,出发! 秋游回来第二天就要提交一篇心得报告,组长在焦急等待:张三、李四、王五谁先写好就交谁的

Unity3D自带Mouse Look鼠标视角代码解析。

Unity3D自带Mouse Look鼠标视角代码解析。 代码块 代码块语法遵循标准markdown代码,例如: using UnityEngine;using System.Collections;/// MouseLook rotates the transform based on the mouse delta./// Minimum and Maximum values can

简单的角色响应鼠标而移动

actor类 //处理移动距离,核心是找到角色坐标在世界坐标的向量的投影(x,y,z),然后在世界坐标中合成,此CC是在地面行走,所以Y轴投影始终置为0; using UnityEngine; using System.Collections; public class actor : MonoBehaviour { public float speed=0.1f; CharacterCo

【经验交流】修复系统事件查看器启动不能时出现的4201错误

方法1,取得『%SystemRoot%\LogFiles』文件夹和『%SystemRoot%\System32\wbem』文件夹的权限(包括这两个文件夹的所有子文件夹的权限),简单点说,就是使你当前的帐户拥有这两个文件夹以及它们的子文件夹的绝对控制权限。这是最简单的方法,不少老外说,这样一弄,倒是解决了问题。不过对我的系统,没用; 方法2,以不带网络的安全模式启动,运行命令行,输入“ne