博客
关于我
js实现可拖拽的div
阅读量:612 次
发布时间:2019-03-13

本文共 2486 字,大约阅读时间需要 8 分钟。

HTML拖拽元素实现

下午忙里偷闲想写一个可拖拽的例子,脑海里一直都是三个事件mouseDown,mouseUp,mouseMove,但从未动手实践过。今天终于动手实践,并学习了张鑫旭的demo实现。学习张鑫旭代码的同时,也了解了几点知识点。

获取DOM非行间样式

通过对currentStyle和getComputedStyle的研究,我了解到获取DOM非行间样式有两种方法:obj.currentStyle[attr]和getComputedStyle(obj,false)[attr]。经过百度,发现Chrome和FF不支持currentStyle,因此选择了这两种方法来兼容不同浏览器。

防止内容被选中

在实现onselectstart事件时,发现IE和Chrome默认会阻止内容被选中。为了让拖拽更流畅,我设置onselectstart的返回值为false。

拖拽原理

可拖拽的div元素主要依赖于mouseDown、mouseMove和mouseUp三个事件。首先是确定mouseDown事件发生时的DOM承载对象,以及mouseMove时的坐标计算。其次是当拖拽完成时的DOM承载对象,我选择了document作为承载对象。这个选择是否正确,需要根据实际需求来决定。

拖拽效果图

拖拽后可以看到div元素沿着鼠标移动的方向改变位置。这一效果通过在mouseMove事件中更新target的left和top属性来实现。

JavaScript实现

以下是实现可拖拽效果的JavaScript代码:

/** 拖拽div * 关键事件:mouseDown, mouseMove,mouseUp */var params = {    top: 0,    left: 0,    currentX: 0,    currentY: 0,    flag: false};/** obj.currentStyle[attr] || getComputedStyle(obj,false)[attr] 获取DOM非行间样式 */var getCss = function(o, key) {    return o.currentStyle ? o.currentStyle[key] : document.defaultView.getComputedStyle(o, false)[key];};var startDrag = function(bar, target, callback) {    if (getCss(target, 'left') !== 'auto') {        params.left = getCss(target, 'left');    }    if (getCss(target, 'top') !== 'auto') {        params.top = getCss(target, 'top');    }    bar.onmousedown = function(event) {        params.flag = true;        if (!event) {            event = window.event;            bar.onselectstart = function() {                // IE和Chrome适用,防止内容被选中默认是true                return false;            }        }        var e = event;        params.currentX = e.clientX;        params.currentY = e.clientY;    };    document.onmouseup = function() {        params.flag = false;        if (getCss(target, "left") !== 'auto') {            params.left = getCss(target, 'left');        }        if (getCss(target, 'top') !== 'auto') {            params.top = getCss(target, 'top');        }    };    document.onmousemove = function(event) {        var e = event ? event : window.event;        if (params.flag) {            var nowX = e.clientX,                nowY = e.clientY;            var disX = nowX - params.currentX,                disY = nowY - params.currentY;            target.style.left = params.left + disX + 'px';            target.style.top = params.top + disY + 'px';        }        if (callback === 'function') {            callback(params.left + disX, params.top + disY);        }    };};

总结

通过以上方法,可以轻松实现一个可拖拽的div元素。整个实现过程主要包括获取非行间样式、防止内容被选中以及处理拖拽事件。虽然过程中遇到了一些小问题,但通过查阅资料和不断尝试,最终达成了预期效果。

转载地址:http://stbaz.baihongyu.com/

你可能感兴趣的文章
No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
查看>>
NO.23 ZenTaoPHP目录结构
查看>>
NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
查看>>
NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
查看>>
Node JS: < 一> 初识Node JS
查看>>
Node-RED中使用JSON数据建立web网站
查看>>
Node-RED中使用json节点解析JSON数据
查看>>
Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
查看>>
Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
查看>>
Node-RED中实现HTML表单提交和获取提交的内容
查看>>
Node.js 函数是什么样的?
查看>>
Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
查看>>
node.js 怎么新建一个站点端口
查看>>
Node.js 文件系统的各种用法和常见场景
查看>>
node.js 配置首页打开页面
查看>>
node.js+react写的一个登录注册 demo测试
查看>>
Node.js中环境变量process.env详解
查看>>
Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
查看>>
Node.js的循环与异步问题
查看>>
Nodejs express 获取url参数,post参数的三种方式
查看>>