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 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测