Toggle navigation
在线编辑器
在线代码
文本比较
jQuery下载
前端库
在线手册
登录/注册
UI
|
输入
|
媒体
|
导航
|
其他
|
网页模板
|
APP模板
|
常用代码
|
在线代码
背景
对话框和灯箱
筛选及排序
反馈
弹出层
悬停
布局
图表
加载
圆边
滚动
标签
文本链接
工具提示
网络类型
拾色器
定制和风格
日期和时间
拖和放
通用输入
自动完成
密码
投票率
搜索
选择框
快捷键
触摸
丰富的输入
上传
验证
音频和视频
幻灯片和轮播图
图片展示
图像
地图
滑块和旋转
Tabs
水平导航
垂直导航
文件树
分页
手风琴菜单
其他导航
动画效果
浏览器调整
移动
独立的部件
杂项
游戏
PROMULGATOR
浅殇忆
江苏省南京市
关注作者
(0)
收藏此代码
(133)
← jquery倒计时
→ 页面倒计时效果
相关代码
原生
js
拖动
可
拖动
div
js
div自由
拖动
js
拖动
改变div
js
拖动
重力碰撞
js
范围内
拖动
、缩放
js
拖动
模态框(原创)
Html
Css
Js
#main { width:100px; height:100px; background:#ffccff; position:absolute; }
/*1:拖拽的时候有文字选中会有问题; 原因:这是浏览器的默认拖拽文字的行为 解决方案:标准浏览器下:阻止默认行为,在onmousedown结尾加上return false即可 ie8及其以下版本:设置全局捕获,方法如下设置全局捕获setCapture最后释放releaseCapture */ var oDiv = document.getElementById("main"); var odiv = document.getElementById("div"); oDiv.onmousedown = function(ev) { var ev = ev || event; var disX = ev.clientX - this.offsetLeft; var disY = ev.clientY - this.offsetTop; if (oDiv.setCapture) { oDiv.setCapture(); } document.onmousemove = function(ev) { //这里为什么使用document,是因为快速拖拽的话会鼠标丢失, var ev = ev || event; oDiv.style.left = ev.clientX - disX + "px"; oDiv.style.top = ev.clientY - disY + "px"; } document.onmouseup = function(ev) { document.onmousemove = document.onmouseup = null; //为何不用oDiv.onmouseup是因为被挡住之后会无视掉遮挡的元素 if (oDiv.releaseCapture) { oDiv.releaseCapture(); } } return false; }
↑上面代码改变,会自动显示代码结果 jQuery调用版本:
1.11.3
立即下载
原生js拖动
代码描述:原生js拖动,兼容各种浏览器
0
最新
发表评论
全部评论
暂时没有评论!
登录后才可以评论
30秒后在评论吧!
发表评论
回复
取消回复
<!doctype html> <html> <head> <meta charset="utf-8"> <title>原生js拖动-jq22.com</title> <script src="https://libs.baidu.com/jquery/1.11.3/jquery.min.js"></script> <style>
</style> </head> <body>
<script>
</script>
</body> </html>
2012-2021 jQuery插件库版权所有
jquery插件
|
jq22工具库
|
网页技术
|
广告合作
|
在线反馈
|
版权声明
沪ICP备13043785号-1
浙公网安备 33041102000314号