javascript实现简单的鼠标拖动效果实例


Posted in Javascript onApril 10, 2015

本文实例讲述了javascript实现简单的鼠标拖动效果。分享给大家供大家参考。具体分析如下:

用鼠标拖动一个元素,放到网页的任意一个位置上,这是很常见的,例如很多博客模板版块位置可以自己拖动到相应位置。

下面先写一个简单的可以实现鼠标拖动的效果。

当鼠标按下的时候,记录鼠标当前位置和元素左边距离的差值。
当鼠标移动的时候,给元素的位置赋值,就是鼠标的位置,减去刚才的差值。
当鼠标放开的时候,给鼠标移动和鼠标放开赋值null,让它们不要再有任何动作。

要点一:

disx = oevent.clientX - box.offsetLeft;

要确定拖动的时候鼠标点在元素的位置,就是鼠标位置减去元素的左边距离。

要点二:

box.style.left = oevent.clientX - disx + "px";

拖动时元素的位置,鼠标的当前位置减去前面刚计算的值。

好了,上代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>无标题文档</title>
<style>
body{margin:0; padding:0; height:1500px;}
#box{width:100px; height:100px; background:#06c; position:absolute;}
</style>
<script>
window.onload = function(){
 var box = document.getElementById("box");
 var disx =0;
 var disy = 0;
 box.onmousedown = function(evt){
 var oevent = evt || window.event;
 disx = oevent.clientX - box.offsetLeft;
 disy = oevent.clientY - box.offsetTop;
 document.onmousemove = function(evt){
  var oevent = evt || window.event;
  box.style.left = oevent.clientX - disx + "px";
  box.style.top = oevent.clientY - disy + "px";
 }
 document.onmouseup = function(){
  document.onmousemove = null;
  document.onmouseup = null;
 }
 return false;
 }
}
</script>
</head>
<body>
<h1>鼠标拖动</h1>
<div id="box"></div>
</body>
</html>

再改进一下,上面的鼠标拖动没有限制范围,有时会拖动窗口外面看不见了。下面就限制下范围

要点一:如下,如果元素的左边位置小于0时,给它赋值为0,如果大于可视窗大小减去元素本身的宽度的,给它赋值为 可视窗大小减元素本身宽度的差值。

var boxl = oevent.clientX - disx;
if(boxl < 0){
  boxl =0;
  }else if(boxl > vieww - box.offsetWidth){
  boxl = vieww - box.offsetWidth;
  }
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>无标题文档</title>
<style>
body{margin:0; padding:0;}
#box{width:100px;
height:100px;
background:#06c;
position:absolute;
}
</style>
<script>
window.onload = function(){
 var box = document.getElementById("box");
 var disx =0;
 var disy = 0;
 box.onmousedown = function(evt){
 var oevent = evt || window.event;
 disx = oevent.clientX - box.offsetLeft;
 disy = oevent.clientY - box.offsetTop;
 document.onmousemove = function(evt){
  var oevent = evt || window.event;
  var boxl = oevent.clientX - disx;
  var boxt = oevent.clientY - disy
  var vieww = document.documentElement.clientWidth || document.body.clientWidth;
  var viewh = document.documentElement.clientHeight || document.body.clientHeight;
  if(boxl < 0){
  boxl =0;
  }else if(boxl > vieww - box.offsetWidth){
  boxl = vieww - box.offsetWidth;
  }
  if(boxt < 0){
  boxt =0;
  }else if(boxt > viewh - box.offsetHeight){
  boxt = viewh- box.offsetHeight;
  }
  box.style.left = boxl + "px";
  box.style.top = boxt + "px";
 }
 document.onmouseup = function(){
  document.onmousemove = null;
  document.onmouseup = null;
 }
 return false;
 }
}
</script>
</head>
<body>
<h1>鼠标拖动</h1>
<div id="box"></div>
</body>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
jQuery中文入门指南,翻译加实例,jQuery的起点教程
Feb 09 Javascript
使用JQuery和CSS模拟超链接的用户单击事件的实现代码
May 23 Javascript
jquery 插件学习(一)
Aug 06 Javascript
jQuery实现页面顶部下拉广告
Dec 30 Javascript
JS实现线性表的链式表示方法示例【经典数据结构】
Apr 11 Javascript
JS实现HTML页面中动态显示当前时间完整示例
Jul 30 Javascript
vue中的ref和$refs的使用
Nov 22 Javascript
防止Layui form表单重复提交的实现方法
Sep 10 Javascript
vue3 源码解读之 time slicing的使用方法
Oct 31 Javascript
jQuery 选择器用法基础入门示例
Jan 04 jQuery
解决Vue router-link绑定事件不生效的问题
Jul 22 Javascript
(开源)微信小程序+mqtt,esp8266温湿度读取
Apr 02 Javascript
js简单实现点击左右运动的方法
Apr 10 #Javascript
js实现透明度渐变效果的方法
Apr 10 #Javascript
js实现同一页面多个运动效果的方法
Apr 10 #Javascript
js实现同一个页面多个渐变效果的方法
Apr 10 #Javascript
js实现缓冲运动效果的方法
Apr 10 #Javascript
js实现分享到随页面滚动而滑动效果的方法
Apr 10 #Javascript
js实现同一页面多个不同运动效果的方法
Apr 10 #Javascript
You might like
用php实现的获取网页中的图片并保存到本地的代码
2010/01/05 PHP
真正根据utf8编码的规律来进行截取字符串的函数(utf8版sub_str )
2012/10/24 PHP
PHP表单递交控件名称含有点号(.)会被转化为下划线(_)的处理方法
2013/01/06 PHP
php中让上传的文件大小在上传前就受限制的两种解决方法
2013/06/24 PHP
php中的字符编码转换函数用法示例
2014/10/20 PHP
yii框架搜索分页modle写法
2016/12/19 PHP
PHP框架自动加载类文件原理详解
2017/06/06 PHP
分享精心挑选的23款美轮美奂的jQuery 图片特效插件
2012/08/14 Javascript
实例说明为什么不要行内使用javascript
2014/04/18 Javascript
Jquery Ajax方法传值到action的方法
2014/05/11 Javascript
详谈JavaScript的闭包及应用
2017/01/17 Javascript
jQuery实现frame之间互通的方法
2017/06/26 jQuery
BootStrap点击保存后实现模态框自动关闭的思路(模态框)
2017/09/26 Javascript
js实现数组内数据的上移和下移的实例
2017/11/14 Javascript
JavaScript数组基于交换的排序示例【冒泡排序】
2018/07/21 Javascript
Vue+axios封装请求实现前后端分离
2020/10/23 Javascript
详解React中共享组件逻辑的三种方式
2021/02/02 Javascript
python验证码识别的实例详解
2016/09/09 Python
Python实现希尔排序算法的原理与用法实例分析
2017/11/23 Python
python文件拆分与重组实例
2018/12/10 Python
详解Python sys.argv使用方法
2019/05/10 Python
Pandas0.25来了千万别错过这10大好用的新功能
2019/08/07 Python
Pytorch中的variable, tensor与numpy相互转化的方法
2019/10/10 Python
解决Python中导入自己写的类,被划红线,但不影响执行的问题
2020/07/13 Python
布局和排版教程 纯css3实现图片三角形排列
2014/10/17 HTML / CSS
Lookfantastic德国官网:英国知名美妆购物网站
2017/06/11 全球购物
美国在线乐器和设备商店:Musician’s Friend
2018/07/06 全球购物
介绍一下EJB的分类及其各自的功能及应用
2016/08/23 面试题
临床医学专业学生的自我评价分享
2013/11/21 职场文书
校园自助餐厅的创业计划书
2013/12/26 职场文书
推普周活动总结
2014/08/28 职场文书
学校政风行风整改方案
2014/10/25 职场文书
关于法制教育的宣传语
2015/07/13 职场文书
2016年过年放假安排通知
2015/08/18 职场文书
SpringBoot2 参数管理实践之入参出参与校验的方式
2021/06/16 Java/Android
Java中PriorityQueue实现最小堆和最大堆的用法
2021/06/27 Java/Android