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

相关文章

禁止平板,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

BT天堂网站挂马事件后续:“大灰狼”远控木马分析及幕后真凶调查

9月初安全团队披露bt天堂网站挂马事件,该网站被利用IE神洞CVE-2014-6332挂马,如果用户没有打补丁或开启安全软件防护,电脑会自动下载执行大灰狼远控木马程序。 鉴于bt天堂电影下载网站访问量巨大,此次挂马事件受害者甚众,安全团队专门针对该木马进行严密监控,并对其幕后真凶进行了深入调查。 一、“大灰狼”的伪装 以下是10月30日一天内大灰狼远控的木马样本截图,可以看到该木马变种数量不

react笔记 8-19 事件对象、获取dom元素、双向绑定

1、事件对象event 通过事件的event对象获取它的dom元素 run=(event)=>{event.target.style="background:yellowgreen" //event的父级为他本身event.target.getAttribute("aid") //这样便获取到了它的自定义属性aid}render() {return (<div><h2>{

react笔记 8-18 事件 方法 定义方法 获取/改变数据 传值

1、定义方法并绑定 class News extends React.Component {constructor(props) {super(props)this.state = {msg:'home组件'}}run(){alert("我是一个run") //方法写在类中}render() {return (<div><h2>{this.state.msg}</h2><button onCli

【Qt】定时器事件

定时器事件 在之前学习QTimer中实现了定时器的功能,而在QTimer背后是QTimerEvent定时器事件进行支撑的。在QObject中提供了一个timeEvent这个函数。 startTimer启动定时器killTimer关闭定时器 Qt 中在进⾏窗⼝程序的处理过程中,经常要周期性的执⾏某些操作,或者制作⼀些动画效果,使⽤定 时器就可以实现。所谓定时器就是在间隔⼀定时间后,去执⾏某⼀