如何实现一个元素的拖拽效果,使用原生的js实现,习惯了jquery的同学们,你们自己写了吗?N久使用mvvm框架,不写jquery的东西,感觉自己完全不会了。

话不多说,直接上code。本例子以简单的div为例子。

html

  1. <div id="div">我是一个可以退拽的div</div>

css

  1. div {
  2. position: fixed;
  3. left: 0;
  4. top: 0;
  5. width: 100px;
  6. height: 100px;
  7. background: #999;
  8. padding: 10px;
  9. cursor: pointer;
  10. }

javascript

  1. window.onload = funtion() {
  2. const div = document.getElementById('div');
  3. let initPosition = {};
  4. div.addEventListener('mousedown', onMousedown);
  5. function onMousedown(event) {
  6. const { pageX, pageY } = event;
  7. initPosition = getPosition();
  8. document.addEventListener('mousemove', omMousemove);
  9. document.addEventListener('mouseup', onMouseUp);
  10. }
  11. function omMousemove(event) {
  12. const { pageX, pageY } = event;
  13. const { left, top} = calcPosition(pageX, pageY);
  14. div.style.cssText = `left:${left}px;top:${top}px;`;
  15. }
  16. function onMouseUp(event) {
  17. document.removeEventListener('mousemove', onMouseMove);
  18. }
  19. function calcPosition(pageX, pageY) {
  20. const { left, top, scrollLeft, maxCriticalX, maxCriticalY } = initPosition;
  21. let x = pageX - left;
  22. let y = pageY - top;
  23. if (x <= scrollLeft) {
  24. x = scrollLeft;
  25. }
  26. if (x >= maxCriticalX) {
  27. x = maxCriticalX;
  28. }
  29. if (y >= maxCriticalY) {
  30. y = maxCriticalY;
  31. }
  32. if ( y<=0 || maxCriticalY < 0) {
  33. y = 0;
  34. }
  35. return {
  36. left: x,
  37. top: y
  38. };
  39. }
  40. function getPosition() {
  41. const { left, top, width, height } = div.getBoundingClientRect();
  42. const { scrollLeft, scrollTop } = document.body;
  43. const maxCriticalX = scrollLeft + innerWidth - width;
  44. const maxCriticalY = scrollTop + innerHeight - height;
  45. return {
  46. left,
  47. top,
  48. scrollLeft,
  49. maxCriticalX,
  50. maxCriticalY
  51. };
  52. }
  53. };

 

 

使用mousedown、mousemove、mouseup实现拖拽效果的更多相关文章

  1. js div浮动层拖拽效果代码

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. JQ实现3D拖拽效果

    <!DOCTYPE HTML> <html onselectstart='return false'> <head> <meta http-equiv=&qu ...

  3. 拖拽系列一、JavaScript实现简单的拖拽效果

        前端拖拽相关应用汇总 在现实生活中就像男孩子牵着(拖着)女朋友的手穿过马路:从马路的一端走到另一端这种场景很常见: 而在前端开发中拖拽效果也算是前端开发中应用最常见.最普遍的特效:其拖拽涉及知 ...

  4. jquery监听事件on写法以及简单的拖拽效果

    引子——关于jquery的某些写法 我先不对监听事件做解释,我们先来看下jquery的一些写法吧!我们最常用的是jquery的css()方法,相信大家都会用! 假如用css设置一个属性,我们写法如下: ...

  5. React.js实现原生js拖拽效果及思考

    一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...

  6. WinForm支持拖拽效果

    有一个MSDN客户提问在WinForm中如何实现拖拽效果——比如在WinForm中有一个Button,我要实现的效果是拖拽这个Button到目标位置后生成一个该控件的副本. 其实这个操作主要分成三步走 ...

  7. vue模块拖拽效果

    正巧在之前面试中遇到问实现拖拽效果 当时面试的时候简单回答了实现的方式与逻辑. 现在闲来无事,把这个东西实现了一下. 原理很简单,写的很方便. 数据驱动,建立一个数组,数组初始长度为1 拖动触发时,添 ...

  8. jQuery的DOM操作实例(2)——拖拽效果&&拓展插件

    一.原生JavaScript编写拖拽效果 二.jQuery编写的拖拽效果 三.在jQuery中拓展一个拖拽插件

  9. js拖拽效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. Storage事件及综合案例

    说到Storage事件,那么就得先给大家说一下localstorage和sessionstorage: 1.localStorage和sessionStorage一样都是用来存储客户端临时信息的对象. ...

  2. 模拟赛 提米树 题解 (DP+思维)

    题意: 有一棵棵提米树,满足这样的性质: 每个点上长了一定数量的Temmie 薄片,薄片数量记为这个点的权值,这些点被标记为 1 到 n 的整数,其 中 1 号点是树的根,没有孩子的点是树上的叶子. ...

  3. php流程控制 之循环语句的使用

    循环语句的使用 王同学需要反复往返于北京和大连,就是典型的循环结构.假设王思总投资这个项目需要往返大连100次,每次往返都王同学都会计数一次.难道我们写一百遍同样的代码?显然对于智商极高的程序员来说不 ...

  4. 从零开始开发一个Spring Boot Starter

    一.Spring Boot Starter简介 Starter是Spring Boot中的一个非常重要的概念,Starter相当于模块,它能将模块所需的依赖整合起来并对模块内的Bean根据环境( 条件 ...

  5. 洛谷 P1955 [NOI2015]程序自动分析 题解

    每日一题 day22 打卡 Analysis 离散化+并查集 先离散化所有的约束条件,再处理所有e=1的条件,将i的祖先和j的祖先合并到一个集合中:e=0时,如果i的祖先与j的祖先在同一个集合中,说明 ...

  6. rc.local配置

    1.让系统默认启动的时候执行rc.local 启动我们想要启动进程:如:nginx ,memcached,或者是 php-fpm等! /usr/local/bin/redis-server /etc/ ...

  7. beego 前后端分离登录验证

    conf>app.conf 文件添加一下参数 copyrequestbody=true sessionon =true routers>router.go 文件添加初始化路由 func i ...

  8. Pytest权威教程21-API参考-03-夹具(Fixtures)

    目录 夹具(Fixtures) @ pytest.fixture config.cache的 capsys capsysbinary capfd capfdbinary doctest_namespa ...

  9. 模板 - 数据结构 - 可持久化无旋Treap/PersistentFHQTreap

    有可能当树中有键值相同的节点时,貌似是要对Split和Merge均进行复制的,本人实测:只在Split的时候复制得到了一个WA,但只在Merge的时候复制还是AC,可能是恰好又躲过去了.有人说假如确保 ...

  10. MyBatis项目配置案例详解与Web下的增删改查实现[附项目源码]

    MyBatis项目案例 项目图示: 项目源码地址:https://github.com/JluTiger/mybatispro 1.项目功能 项目案例:后台管理系统用户数据维护平台 所有用户数据查询 ...