首页
学习
活动
专区
圈层
工具
发布

如何用JS实现网页上通过鼠标移动批量选择元素?

鼠标移动,将选择框的大小(height、width)设置为鼠标移动的距离(起始点和终点的差) 鼠标抬起,停止选择框大小跟随鼠标移动,计算与选择框发生重叠的元素。...情形分析 网页上的元素重叠,存在多种不同的情况,针对每一种情况有不同的检测方法。...1.角重叠 角重叠,也就是选择框有至少一个角在元素的范围内,或者元素至少有一个角在选择框的范围内,此时可判断元素被选中。...角重叠 可以通过对选择框和元素进行相互检测,来判断元素是否选中,如图,判断一个点是否在方形内的算法如下: 图例 //简单的判断 if ( X > X1 && X Y1 && Y < Y2 ) { return true; } 通过以上算法循环判断选择框的四个坐标点是否在元素内,然后再判断元素的四个角是否在选择框内,只要存在一个True,

5.7K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS魔法堂:关于元素位置和鼠标位置的属性

    一、关于鼠标位置的属性                           1....触发鼠标事件的区域       盒子模型中的border,padding,content区域会触发鼠标事件,点击margin区域将不触发鼠标事件。   2....HTMLElement.clientLeft/Top :元素左border的宽度和上border的高度。 2.  ...注意:FF在W3C标准模式下,document.documentElement.scrollLeft/Top获取页面滚动条切去的部分;W3C怪异模式下,则采用body.scrollLeft/Top来获取...三、总结                                  在写拖拽层和polyfill html5特性placeholder时,上述内容为基础知识,同时会减少很多不必要的代码。

    7.3K100

    JavaScript 获取鼠标及元素在页面上的位置

    在书写一些“拖拽”页面交互效果,比如常见的拖拽效果、自定滚动条、放大镜等效果,都需要用到了鼠标或元素在页面上的位置信息。...另外,也要跟大家分享一个方法,它能快速的获取元素在页面上的位置信息,不同于之前学过的offsetLeft等属性,它就是——getBoundingClientRect()方法 回顾clientX/Y获取鼠标位置的方式...layerX/Y属性有点坑,如果想让鼠标的位置参考的是自身元素的左上角,需要给自身元素设置position(属性值不能是static | inherit),否则默认参考document文档区域的左上角。...,内容区以内为正值,换句话说鼠标位置是参考自身元素内容区域的左上角(不包括border)。...今天要给大家分享的是另外一种快速获取元素在页面上的位置,赶紧尝试书写一下下面的实例 代码实例: <!

    4.9K60

    JS实现获取鼠标在画布中的位置

    JS实现获取鼠标在画布中的位置 效果展示 概述 本文讲解如何实现我们平时用的画布软件中,怎么获取的我们鼠标时刻在画布中的位置。.../ 用鼠标距离页面的坐标减去盒子在页面中的距离, 得到 鼠标在盒子内的坐标 // 我们生活中常见的画布里面的那个获取鼠标的位置 就是这么实现的 var box = document.querySelector...('.box'); // 获取盒子的元素 box.addEventListener('mousemove', function(e) { // 为盒子添加监听事件 当鼠标在盒子上面的时候.../ 用鼠标距离页面的坐标减去盒子在页面中的距离, 得到 鼠标在盒子内的坐标 // 我们生活中常见的画布里面的那个获取鼠标的位置 就是这么实现的 var box = document.querySelector...('.box'); // 获取盒子的元素 box.addEventListener('mousemove', function(e) { // 为盒子添加监听事件 当鼠标在盒子上面的时候

    3.6K00

    js鼠标事件

    页面加载事件(onload),鼠标双击事件(ondbclick) window.onload=function(){                 //绑定元素,执行对应事件 鼠标双击(ondblclick...)             window.onload=function(){                 //绑定元素,执行鼠标按下操作  鼠标摁下(onmousedown)                 ...//绑定元素,执行鼠标抬起事件   鼠标抬起(onmouseup)                 document.getElementById('d4').onmouseup=function(){...鼠标移入(onmouseover)事件             window.onload=function(){                 //绑定元素,执行鼠标移入事件   鼠标移入(onmousemove...//绑定元素,执行鼠标移出事件   鼠标移出(onmouseout)                 document.getElementById('d7').onmouseout=function(

    23K40

    在鼠标右键上加入使用notepad++编辑

    个人博客:https://suveng.github.io/blog/​​​​​​​ 在鼠标右键上加入使用notepad++编辑 我们在安装完notepad++文本编辑器之后,在一个文本文件上右键有时候并没有出现...“使用notepad++编辑的选项”,我们可以通过简单地修改注册表文件来增加这样的功能: 1、 首先打开注册表,windows+ R运行,在运行窗口中输入regedit,进入注册表编辑器 2、在左边的导航中找到路径...:HKEY_CLASSES_ROOT*\shell 3、 在shell上右键,新建项,命名为editwith notepad++ 4、 在新建的项editwith notepad++上右键,然后新建一个项...command,新建了command之后选中command项会发现右边有相应的值,双击默认进行修改 5、 双击默认后对其值进行修改,先写notepad++的路径,然后写上“%1”,点击确定,在任意文件上右键都会有

    2.4K10

    js鼠标事件

    今天遇到一个非常奇怪而又搞笑的事情:给一个a标签添加一个鼠标移动上时给一个事件,我给其添加的是一个onMouseMove事件,结果在IE6 7 8 9和GOOLE中都很正常,结果在Firox中出现问题了...这是我遇到的第一个在firox中的兼容性问题,开始让我很苦恼,不知道什么原因,结果仔细查找,就是onMouseMove事件在日怪。当我给提添加onMouseOver事件时就对了。...鼠标的一些事件如下所示: onMouseOver IE3|N2|O3 当鼠标移动到某对象范围的上方时触发的事件 onMouseMove IE4|N4|O 鼠标移动时触发的事件 onMouseOut IE4...|N3|O3 当鼠标离开某对象范围时触发的事件 onKeyPress IE4|N4|O 当键盘上的某个键被按下并且释放时触发的事件.

    17.4K30

    通过 JS 实现简单的拖拽功能并且可以在特定元素上禁止拖拽

    前言 关于讲解 JS 的拖拽功能的文章数不胜数,我确实没有必要大费周章再写一篇重复的文章来吸引眼球。本文的重点是讲解如何在某些特定的元素上禁止拖拽。...排除特定元素的方法 关于如何排除特定元素的方法,很多人会推荐阻止冒泡的方法,但是我试了很多次,这种方法是不行的,因为拖拽事件绑定在了 document 对象上。...解决的方法就是在拖拽开始时添加限制条件,代码如下 ......因为我们在排除特定元素的同时也要排除它的子元素。如果使用原生 JS 的话,需要添加获取子元素的方法。...仍然是之前的老话,实现一个功能并不困难,但是如果要把这个功能做好,我们需要考虑很多的细节,或许很多时候我们都把时间花费在调整细节上了。

    5.9K90

    js 鼠标事件总结

    当监听鼠标事件时,会触发一些事件,我们可以与之交互: mousedown 按下鼠标按钮触发 mouseup 鼠标按钮被释放 click 点击事件 dblclick 双击事件 mousemove 当鼠标移动到元素上时...,鼠标移动 mouseover 当鼠标移动到一个元素或它的一个子元素上时,鼠标悬停。...mouseenter 当鼠标移动到一个元素上时,鼠标进入。类似于mouseover但不冒泡。 mouseout 当鼠标移出元素时,以及当鼠标进入子元素时。...我们需要应用节流,这是我们在分析滚动时会详细讨论的东西。 在事件处理程序中,我们可以访问很多事件属性。...buttons 按钮(如果有),表示在任何鼠标事件上按下的按钮的数字。 clientX / clientY 无论是否滚动,鼠标指针相对于浏览器窗口的x和y坐标。

    12.2K40

    js鼠标事件大全

    [鼠标与键盘的触发均可] onChange HTML: 2 | 3 | 3.2 | 4 Browser: IE3 | N2 | O3 当前元素失去焦点并且元素的内容发生改变而触发的事件 [鼠标与键盘的触发均可...IE3 | N2 | O3 一个表单被递交时触发的事件 滚动字幕事件 事件 浏览器支持 描述 onBounce HTML: 2 | 3 | 3.2 | 4 Browser: IE4 | N | O 在Marquee...[试试在页面中的中加入onContentMenu="return false"就可禁止使用鼠标右键了] onCopy HTML: 2 | 3 | 3.2 | 4 Browser: IE5...IE5 | N | O 当对象被鼠标拖动的对象离开其容器范围内时触发的事件 onDragOver HTML: 2 | 3 | 3.2 | 4 Browser: IE5 | N | O 当某被拖动的对象在另一对象容器范围内拖动时触发的事件...,释放鼠标键时触发的事件 onLoseCapture HTML: 2 | 3 | 3.2 | 4 Browser: IE5 | N | O 当元素失去鼠标移动所形成的选择焦点时触发的事件 onPaste

    5.3K10

    使用js在网页上记录鼠标划圈的小程序

    Spin-Wheel 实现鼠标在网页上转圈时记录转动圈数的小程序,每转一圈记录一次,同时要是顺时针方向的。...问题分析与实现 这个小程序的难点在于如何知道鼠标完成了一个转圈的动作,而且人工使用鼠标划圈时也不会是一个标准的圆,通常都是很不规律的。这点上我网上找了找发现浏览器的鼠标手势实现了。...但是我在具体实现的时候想到了另一个方法。 我的实现方法:把一个圆分为4个等分,也就是扇区:左上,左下,右上,右下。...因为鼠标在刚开始时只是在某一个点上,只有移动了一段距离后才知道在哪。我们看一下下面的图: ? 这里面我标识了10个点,我们可以发现鼠标在经过这10个点说明就是画了一个圈,对吧。...也就是说我们只要将鼠标移动的轨迹记录下来,然后逐个点进行分析,只要符合上面规律的就可以理解为在【右上扇区】。

    1.6K60

    在Centos上安装Node.js

    介绍 Node.js是一个能够在服务器端运行JavaScript的开放源代码、跨平台avaScript 运行环境。Node.js由Node.js基金会持有和维护,并与Linux基金会有合作关系。...Node.js大部分基本模块都用JavaScript语言编写。在Node.js出现之前,JavaScript通常作为客户端程序设计语言使用,以JavaScript写出的程序常在用户的浏览器上运行。...所以,学会试用Node.js非常有用,本文概述了在Centos运行node.js + express中运行“Hello world”所需的步骤。...它非常方便,特别是在开发编译的时候。 yum -y install screen 安装Node.js 现在我们已准备好从源安装Node.js。...只需输入: make 这可能是最耗时的任务:在CVM上,完成需要大约6分34秒。

    3.1K00

    python selenium 鼠标移动到指定元素,并点击对应的元素

    在使用selenium 爬去网页信息的时候,我们经常会遇到这样的一个问题。就是某一关键字或者元素,必须是鼠标悬浮上,才会出现,然后才能点击。那下面,我们就用python实现这一功能。...首先需要让,鼠标移动到”项目进度”按钮上面,然后等待’导出音频数据’按钮出现后,才能点击。...1 2 3 4 5 6 7 8 9 10 11 解释一下: ActionChains(driver).move_to_element(elenment) 1 这个方法,是让鼠标移动到指定元素上面...我这里设置最大的等待时间为5秒,如果5秒过后,元素不出现,就会报错,当然这里,你还可以加上一个 try except 进行异常捕获。...另外扩展知识下: 鼠标单击 click 鼠标双击 double_click 鼠标单击并摁住不放 click_and_hold 鼠标拖拽 drag_and_drop 学习博客:https://blog.csdn.net

    6.8K30
    领券