js能实现向下拖拽页面元素然后返回顶部吗?如图,想问下思路,主要可以用啥实现,查了一下好像要用draggable?
js能实现向下拖拽页面元素然后返回顶部吗?如图,想问下思路,主要可以用啥实现
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
4条回答 默认 最新
- 天道酬勤,学无止境 2022-03-10 10:27关注
//鼠标按下事件 定时器判断点击时间超过0.5秒认为是拖拽事件 onMouseDown = (e) => { e.stopPropagation(); let _this = this _this.state.timeOutEvent = setTimeout(function () { _this.longPress() }, 500); e.preventDefault(); var div = document.getElementById("id")//要拖拽的元素id var srcWidth = document.querySelector('body').offsetWidth; var srcHeight = document.querySelector('body').offsetHeight; document.onmousemove = function (e) { clearTimeout(_this.state.timeOutEvent); _this.setState({ timeOutEvent: 0 }) var ev = window.event || e; var x = ev.clientX; var y = ev.clientY; // 我的是宽高80px所以减去一半以免拖出屏幕外 if ((x) >= srcWidth) { } else { div.style.left = (x - 40) + 'px'; divs.style.left = (x - 40) + 'px'; } if ((y - 40) >= srcHeight) { } else { div.style.top = (y - 40) + 'px'; divs.style.top = (y - 40) + 'px'; } return false; } } //鼠标弹起事件 onMouseUp = (e) => { e.stopPropagation(); e.nativeEvent.stopImmediatePropagation(); if (e.target && e.target === document.getElementById("id")) { return; } clearTimeout(_this.state.timeOutEvent); document.onmousemove = null; return false; }
如果帮到你的话请点个采纳~
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 帮我写一个c++工程
- ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
- ¥15 关于smbclient 库的使用
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
- ¥20 怎么用dlib库的算法识别小麦病虫害
- ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
- ¥15 java写代码遇到问题,求帮助
- ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
- ¥15 有了解d3和topogram.js库的吗?有偿请教