romancekami 2022-03-10 08:55 采纳率: 100%
浏览 48
已结题

js能实现向下拖拽页面元素然后返回顶部吗?如图,想问下思路,主要可以用啥实现

js能实现向下拖拽页面元素然后返回顶部吗?如图,想问下思路,主要可以用啥实现,查了一下好像要用draggable?

img

  • 写回答

4条回答 默认 最新

  • 关注
    //鼠标按下事件  定时器判断点击时间超过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人已打赏
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月18日
  • 已采纳回答 3月10日
  • 创建了问题 3月10日

悬赏问题

  • ¥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库的吗?有偿请教