js实现回放拖拽轨迹从过程上进行分析


Posted in Javascript onJune 26, 2014

今天有点小高兴,csdn博客浏览量过万了,在过去还从来没有过这么高的浏览量呢,不得不说,太多时候还是有些矫情,可看到这些鼓励还是忍不住高兴啊,至少,这样让我有一种行内人员的感觉,吾道不孤啊。

闲话不多说,继续今天的记录,记录回放拖拽痕迹,先从过程上进行分析:

1、要实现回放拖拽痕迹,则必须先有记录;

2、要记录拖拽痕迹,则必须要实现拖拽;

这个问题前几天曾经做到过,当时实现的也略有瑕疵,但大致的实现方法已经了然于胸,所以今天在实现这个问题的时候速度快了不少,着实高兴了一番,今天再实现了一遍之后理解上又深了一点,那就今天再来记录下;

至于记录拖拽痕迹,这个分析就来长话短说,毕竟做过一次了:

1、确定现在div的位置和状态,保证absolute才能实现拖动;

2、监听鼠标拖动事件(昨天总结的几种鼠标事件);

3、根据相应的鼠标事件,做出相应的响应,在onmousemove拖拽中记录div存在过的点;

4、监听鼠标弹起事件,来结束拖拽事件和点的记录

任然是先来实现下代码(这里将所有代码同时列出,后面逐一分析):

html语言:

<div style="width: 50px;height: 50px;background-color: cyan;display: block;position: absolute;" id="showZone"></div>//这个还是那么熟悉啊 
<a href="#" style="position: absolute;margin-top: 100px;color: yellow;background-color: red;">reback</a>//这个是来回放的

javascript部分:

window.onload=function(){ 
var obj=document.getElementById("showZone"); 
var disX=disY=0; 
var dragIf=false; 
var position=[{x:obj.offsetLeft,y:obj.offsetTop}];//这个是实现记录和回放的关键,其它都是基本元素的获取 
var oa=document.getElementsByTagName("a")[0]; 

obj.onmousedown=function(event){ 
var event=event||window.event; 
disX=event.clientX-obj.offsetLeft;//鼠标相对于div边框的距离 
disY=event.clientY-obj.offsetTop; 
dragIf=true;//可以进行拖拽的标志 

position.push({x:obj.offsetLeft,y:obj.offsetTop});//记录从这时候就开始了 
return false; 
}; 
document.onmousemove=function(event){ 

if(!dragIf)return;//这个判断极为重要,只有按下的移动才有效 
var event=event||window.event; 
var nowX=event.clientX-disX;//根据上面记录的鼠标相对div的距离就知道div相对网页的距离了吧 
var nowY=event.clientY-disY; 
var maxX=document.documentElement.clientWidth-obj.offsetWidth;//这里是offsetWidth,是div的宽度,不是offsetLeft 
var maxY=document.documentElement.clientHeight-obj.offsetHeight; 
nowX=nowX<0?0:nowX;//这些判定,只是判断不要出了边界 
nowY=nowY<0?0:nowY; 
nowX=nowX>maxX?maxX:nowX; 
nowY=nowY>maxY?maxY:nowY; 

obj.style.marginTop=obj.style.marginLeft=0; 
obj.style.left=nowX+"px";//不要忘记+“px”,只有style.left/top是有“px”的 
obj.style.top=nowY+"px"; 
position.push({x:nowX,y:nowY});//不停记录啊 
obj.innerHTML="X:"+nowX+"Y:"+nowY;//直观的看到变化 
return false; 
}; 
document.onmouseup=function(){ 
dragIf=false;//不允许再进行拖拽和记录了 
obj.innerHTML="X:"+obj.offsetLeft+"Y:"+obj.offsetTop; 
}; 
oa.onclick = function (){ 
if (position.length == 1) return;//只有一个的时候,说明并未移动 
var timer = setInterval(function (){ 
var oPos = position.pop(); 
oPos ? (obj.style.left = oPos.x + "px", obj.style.top = oPos.y + "px") : clearInterval(timer);//又被这个写法惊艳到 
}, 30); 
return false; 
}; 
};

需要注意的关键点,简要说几个:

1、var position数组,点的集合:这个点,是以div的左上角的移动点,也就是说我们记录的移动轨迹实际上就是div左上角的点的集合,offsetLeft为x坐标,offsetTop为y坐标,这个坐标轴你知道怎么画不;

2、程序中出现的几个长度或距离:offsetLeft、clientX、offsetWidth、style.left和document.documentElement.clientWidth等等;

3、push()方法:向数组末尾添加元素,改变数组长度,末尾哦;

4、pop()方法:删除并返回数组的最后一个元素,关键点有两个,其一:返回最后一个元素;其二:删除元素,数组长度变小;

这样我们实现了倒着回放,实现原理就不用多说了吧,如果要是正着回放,我们是不是就要获取并删除数组的第一个值了,哈,试着动手写写看吧。

不得不说还是用鼠标拖起来舒服,键盘移动太不方便了,用鼠标可以肆无忌惮的拖拽啊.....天已入伏,要热,今天倒还好....

Javascript 相关文章推荐
根据出生日期自动取得星座的js代码
Jul 20 Javascript
js实现在文本框光标处添加字符的方法介绍
Nov 24 Javascript
javascript中全局对象的isNaN()方法使用介绍
Dec 19 Javascript
Jquery实现仿京东商城省市联动菜单
Nov 19 Javascript
利用Angular.js限制textarea输入的字数
Oct 20 Javascript
jQuery 中msgTips 顶部弹窗效果实现代码
Aug 14 jQuery
vue2.0+ 从插件开发到npm发布的示例代码
Apr 28 Javascript
vue源码学习之Object.defineProperty对象属性监听
May 30 Javascript
微信小程序登录换取token的教程
May 31 Javascript
vue权限路由实现的方法示例总结
Jul 29 Javascript
layer设置maxWidth及maxHeight解决方案
Jul 26 Javascript
浅谈webpack和webpack-cli模块源码分析
Jan 19 Javascript
JS的事件绑定深入认识
Jun 26 #Javascript
jquery 页眉单行信息滚动显示实现思路及代码
Jun 26 #Javascript
jquery的clone方法应用于textarea和select的bug修复
Jun 26 #Javascript
document.forms用法示例介绍
Jun 26 #Javascript
JS获取当前日期时间并定时刷新示例
Mar 04 #Javascript
使用ajaxfileupload.js实现ajax上传文件php版
Jun 26 #Javascript
一个简单的jQuery插件ajaxfileupload.js实现ajax上传文件例子
Jun 26 #Javascript
You might like
如何使用动态共享对象的模式来安装PHP
2006/10/09 PHP
PHP中类的继承和用法实例分析
2016/05/24 PHP
php swoft框架实例用法
2020/12/22 PHP
JS动态调用方法名示例介绍
2013/12/18 Javascript
JS中处理时间之setUTCMinutes()方法的使用
2015/06/12 Javascript
jquery+css实现的红色线条横向二级菜单效果
2015/08/22 Javascript
AngularJS基础 ng-dblclick 指令用法
2016/08/01 Javascript
再谈Javascript中的异步以及如何异步
2016/08/19 Javascript
TypeScript学习之强制类型的转换
2016/12/27 Javascript
fullpage.js最后一屏滚动方式
2018/02/06 Javascript
利用Console来Debug的10个高级技巧汇总
2018/03/26 Javascript
Vue渲染过程浅析
2019/03/14 Javascript
JS工厂模式开发实践案例分析
2019/10/17 Javascript
vue中使用WX-JSSDK的两种方法(推荐)
2020/01/18 Javascript
jQuery HTML css()方法与css类实例详解
2020/05/20 jQuery
微信小程序仿抖音短视频切换效果的实例代码
2020/06/24 Javascript
python测试驱动开发实例
2014/10/08 Python
基于Python实现的百度贴吧网络爬虫实例
2015/04/17 Python
Python利用正则表达式实现计算器算法思路解析
2018/04/25 Python
pybind11和numpy进行交互的方法
2019/07/04 Python
python处理document文档保留原样式
2019/09/23 Python
anaconda3安装及jupyter环境配置全教程
2020/08/24 Python
python 删除系统中的文件(按时间,大小,扩展名)
2020/11/19 Python
PyTorch中clone()、detach()及相关扩展详解
2020/12/09 Python
饭店工作计划书
2014/01/10 职场文书
小学生演讲稿
2014/01/12 职场文书
行政助理工作职责范本
2014/03/04 职场文书
普通党员个人对照检查材料
2014/09/18 职场文书
缓刑期间思想汇报范文
2014/10/10 职场文书
罚款通知怎么写
2015/04/22 职场文书
2019公司管理制度
2019/04/19 职场文书
原生JS实现飞机大战小游戏
2021/06/09 Javascript
使用pandas生成/读取csv文件的方法实例
2021/07/09 Python
与Windows10相比Windows11有哪些改进?值不值得升级?
2021/11/21 数码科技
Python实现提取PDF简历信息并存入Excel
2022/04/02 Python
浅析JavaScript中的变量提升
2022/06/01 Javascript