首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

js实现简易拖拽

简易拖拽 目录 代码实例 代码解析 scrollWidth,clientWidth,offsetWidth区别 offsetX,clientX,pageX辨析 下载源码链接 代码实例 <...x: x, y: y } } })() 代码解析 在 document 对象上绑定 mousemove 和 mouseup 事件,不在拖拽元素上绑定是因为当鼠标移动太快而超出元素范围时会停止拖拽...拖拽再快都不会超出 document 范围。...定义 scrollWidth:对象实际内容宽度,不包括边线宽度 clientWidth:对象内容可视区宽度,不包括边线宽度 offsetWidth:对象整体实际宽度,包括滚动条等边线...scrollWidth > clientWidth offsetWidth为元素实际宽度 offsetX,clientX,pageX辨析 offsetX,offsetY 指鼠标指针相对于触发事件元素左上角偏移

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

    js 实现元素拖拽

    概述 js 实现拖拽,主要使用元素 onmousedown、onmousemove、onmouseup 三个事件实现。...1、onmousedown:鼠标按下事件 2、onmousemove:鼠标移动事件 3、onmouseup:鼠标抬起事件 实现思路 我们当左键点击时,需要记录当前鼠标点击位置相对于该元素左上角x,y...坐标,这里我们使用diffX和diffY来表示 然后我们移动时需要不断计算当前元素距离浏览器左边和上边距离; 同时给元素进行赋值; 当鼠标抬起时,取消鼠标移动事件和鼠标抬起事件。...// 浏览器兼容 e = e || window.event; // 元素...clientX 和 clientY 默认是以元素左上角位置来计算,这里需要向左向上同时减去鼠标点击位置差,从而可以保证鼠标始终显示在拖拽元素时位置

    10K30

    js拖拽

    开发了那么久,对于js实现拖拽多少都写过,用于实际项目却没有。 先看一下之前写: 如果鼠标慢慢移动,拖拽是没有任何问题,如果速度快了,那么鼠标和元素就会分离。...因为我们是监听鼠标移动事件,鼠标移动时候需要执行我们定义函数,函数执行会有一些延时,当鼠标移动速度过快,导致函数延时使得元素跟不上鼠标移动速度,从而鼠标移出了元素,也就造成了元素不跟随鼠标了。...解决办法就是把监听元素换成document或者body,当函数执行延时了,因为鼠标还是在document和body上,也能一直触发函数,两者效果是一样,只有一个小区别 document: ?...两者都能很流畅拖动,区别就是浏览器上面的地方,不属于body,所以使用body会失效,建议使用document最好。 最后贴上代码: <!...之前在vue里面移除时候就遇到过这个问题。如果是想移动端使用,就都改成监听touch,任何用touches里面的参数。当然,你也可以去写一个兼容PC和移动端。 (完)

    5.4K30

    原生JS 实现页面元素拖动 拖拽

    大家好,又见面了,我是你们朋友全栈君。 1 ....实现原理 要实现页面元素拖动,其原理就是根据鼠标的移动实时更改元素left 和 top值(当然元素肯定是要做绝对定位),那么就达到我们要效果了呀!...鼠标的位置是可以通过 e.clientX 获取,通过获取值减去鼠标和目标元素之间偏移量,就是我们 left 值了呗, top值是同理,不过记住要设置界限哟,不然跑出去了。...代码我尽量写了注释,如果还是有什么不懂,直接评论就好了,我会尽快回复。 2 . 实例展示 <!...; // 我们想要拖拽元素,其实就是根据鼠标的移动实时更改元素left 和 top值 // 鼠标的位置是可以通过e.clientX 获取,然后减去x 不就是我们left值了 //鼠标移动,肯定是在按住情况下移动

    5.3K30

    HTML5、JS实现元素拖拽排序

    先介绍一下html5drag属性,拖放(Drag 和 drop)是 HTML5 标准组成部分。...拖动事件事件分为两类,当前拖动元素上事件,以及要放置位置接收到事件。...一.发生在拖动元素上事件:事件名 触发时机 触发次数dragstart 当拖动开始时触发一次 1drag 拖动开始后反复触发 ndragend 拖动结束后触发一次二.发生在目标元素上事件事件名 触发时机...触发次数dragenter 当拖动元素进入目标时触发一次 1dragover 当拖动元素在目标元素范围内时反复触发 ndrop 拖动元素在目标元素内释放时(在设置了dropover事件前提下) 1信息传递在拖动元素时可以设置传递信息...el.parentNode) { return -1; } //previousElementSibling属性返回指定元素前一个兄弟元素(相同节点树层中前一个元素节点

    51760

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

    前言 关于讲解 JS 拖拽功能文章数不胜数,我确实没有必要大费周章再写一篇重复文章来吸引眼球。本文重点是讲解如何在某些特定元素上禁止拖拽。...拖拽实现 关于拖拽功能不再啰嗦,直接贴代码 /** * [draggable 拖拽方法] * @param {[type]} modal [移动元素] * @param {[type]} handle...因为我们在排除特定元素同时也要排除它子元素。如果使用原生 JS 的话,需要添加获取子元素方法。...总结 其实这个拖拽案例算是 jquery ui 拖拽功能简单实现。...仍然是之前老话,实现一个功能并不困难,但是如果要把这个功能做好,我们需要考虑很多细节,或许很多时候我们都把时间花费在调整细节上了。

    4.9K90
    领券