欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js實現(xiàn)回放拖拽軌跡從過程上進行分析

 更新時間:2014年06月26日 10:19:03   投稿:whsnow  
今天的記錄,記錄回放拖拽痕跡,先從過程上進行分析,需要的朋友可以參考下

今天有點小高興,csdn博客瀏覽量過萬了,在過去還從來沒有過這么高的瀏覽量呢,不得不說,太多時候還是有些矯情,可看到這些鼓勵還是忍不住高興啊,至少,這樣讓我有一種行內(nèi)人員的感覺,吾道不孤啊。

閑話不多說,繼續(xù)今天的記錄,記錄回放拖拽痕跡,先從過程上進行分析:

1、要實現(xiàn)回放拖拽痕跡,則必須先有記錄;

2、要記錄拖拽痕跡,則必須要實現(xiàn)拖拽;

這個問題前幾天曾經(jīng)做到過,當時實現(xiàn)的也略有瑕疵,但大致的實現(xiàn)方法已經(jīng)了然于胸,所以今天在實現(xiàn)這個問題的時候速度快了不少,著實高興了一番,今天再實現(xiàn)了一遍之后理解上又深了一點,那就今天再來記錄下;

至于記錄拖拽痕跡,這個分析就來長話短說,畢竟做過一次了:

1、確定現(xiàn)在div的位置和狀態(tài),保證absolute才能實現(xiàn)拖動;

2、監(jiān)聽鼠標拖動事件(昨天總結(jié)的幾種鼠標事件);

3、根據(jù)相應的鼠標事件,做出相應的響應,在onmousemove拖拽中記錄div存在過的點;

4、監(jiān)聽鼠標彈起事件,來結(jié)束拖拽事件和點的記錄

任然是先來實現(xiàn)下代碼(這里將所有代碼同時列出,后面逐一分析):

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}];//這個是實現(xiàn)記錄和回放的關(guān)鍵,其它都是基本元素的獲取 
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;//根據(jù)上面記錄的鼠標相對div的距離就知道div相對網(wǎng)頁的距離了吧 
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; 
}; 
};

需要注意的關(guān)鍵點,簡要說幾個:

1、var position數(shù)組,點的集合:這個點,是以div的左上角的移動點,也就是說我們記錄的移動軌跡實際上就是div左上角的點的集合,offsetLeft為x坐標,offsetTop為y坐標,這個坐標軸你知道怎么畫不;

2、程序中出現(xiàn)的幾個長度或距離:offsetLeft、clientX、offsetWidth、style.left和document.documentElement.clientWidth等等;

3、push()方法:向數(shù)組末尾添加元素,改變數(shù)組長度,末尾哦;

4、pop()方法:刪除并返回數(shù)組的最后一個元素,關(guān)鍵點有兩個,其一:返回最后一個元素;其二:刪除元素,數(shù)組長度變??;

這樣我們實現(xiàn)了倒著回放,實現(xiàn)原理就不用多說了吧,如果要是正著回放,我們是不是就要獲取并刪除數(shù)組的第一個值了,哈,試著動手寫寫看吧。

不得不說還是用鼠標拖起來舒服,鍵盤移動太不方便了,用鼠標可以肆無忌憚的拖拽啊.....天已入伏,要熱,今天倒還好....

相關(guān)文章

  • JavaScript中事件委托的示例詳解

    JavaScript中事件委托的示例詳解

    所謂事件委托,就是將原本應該在當前元素綁定的事件,放到它的祖先元素上,讓祖先元素來委托處理。今天我們來認識一下JS中的事件委托
    2022-07-07
  • 通過js控制時間,一秒一秒自己動的實例

    通過js控制時間,一秒一秒自己動的實例

    下面小編就為大家?guī)硪黄ㄟ^js控制時間,一秒一秒自己動的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • turn.js異步加載實現(xiàn)翻書效果

    turn.js異步加載實現(xiàn)翻書效果

    這篇文章主要為大家詳細介紹了turn.js異步加載實現(xiàn)翻書效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • 在網(wǎng)頁中插入百度地圖的步驟詳解

    在網(wǎng)頁中插入百度地圖的步驟詳解

    在企業(yè)網(wǎng)站中常會看到企業(yè)地址會顯示在地圖上,那么,如何實現(xiàn)這種功能呢?本篇文章就主要介紹在網(wǎng)頁中插入百度地圖的步驟,下面就隨小編一起來看看吧
    2016-12-12
  • 判斷js數(shù)據(jù)類型的函數(shù)實例詳解

    判斷js數(shù)據(jù)類型的函數(shù)實例詳解

    這篇文章主要介紹了一個判斷js數(shù)據(jù)類型的函數(shù),本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • 基于原生JS實現(xiàn)分頁效果的示例代碼

    基于原生JS實現(xiàn)分頁效果的示例代碼

    這篇文章主要為大家詳細介紹了如何利用原生js實現(xiàn)分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 解析ES6中的解構(gòu)賦值(數(shù)組,對象,嵌套,默認值)

    解析ES6中的解構(gòu)賦值(數(shù)組,對象,嵌套,默認值)

    解構(gòu)賦值是一種特殊的語法,它使我們可以將數(shù)組或?qū)ο蟆安鸢敝烈幌盗凶兞恐?,因為有時這樣更方便,接下來通過本文給大家介紹ES6中的解構(gòu)賦值(數(shù)組,對象,嵌套,默認值),需要的朋友可以參考下
    2022-11-11
  • javascript實現(xiàn)導航欄分頁效果

    javascript實現(xiàn)導航欄分頁效果

    這篇文章主要為大家詳細介紹了javascript實現(xiàn)導航欄分頁效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • 前端面試運行npm?run?xxx發(fā)生過程原理解析

    前端面試運行npm?run?xxx發(fā)生過程原理解析

    這篇文章主要為大家介紹了前端面試運行npm?run?xxx過程原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • JavaScript學習筆記之數(shù)組去重

    JavaScript學習筆記之數(shù)組去重

    這篇文章主要介紹了JavaScript學習筆記之數(shù)組去重的相關(guān)資料,需要的朋友可以參考下
    2016-03-03

最新評論