JS實(shí)現(xiàn)移動(dòng)端判斷上拉和下滑功能
一、手指觸屏,利用touchstart和touchend計(jì)算前后滑動(dòng)距離,判斷是上拉還是下滑。
二、js中距離:pageY、clientY、offsetY的區(qū)別:
offsetY:相對(duì)于父節(jié)點(diǎn)的偏移距離。
clientY:相對(duì)于瀏覽器,滾輪距離不算在內(nèi)。
pageY:相對(duì)于瀏覽器,滾輪滾動(dòng)的距離算在內(nèi);本例中,用pageY,觸屏?xí)r記錄位置-startY,結(jié)束時(shí)記錄-endY,兩個(gè)相減以正負(fù)判斷是上移還是下滑。
三、touchstart有touches屬性,touchend有changedTouches屬性,兩個(gè)屬性中分別有pageY、pageX信息。
//滑動(dòng)處理 var startX, startY; document.addEventListener('touchstart',function (ev) { startX = ev.touches[0].pageX; startY = ev.touches[0].pageY; }, false); document.addEventListener('touchend',function (ev) { var endX, endY; endX = ev.changedTouches[0].pageX; endY = ev.changedTouches[0].pageY; var direction = GetSlideDirection(startX, startY, endX, endY); switch(direction) { case 0: alert("無(wú)操作"); break; case 1: // 向上 alert("up"); break; case 2: // 向下 alert("down"); break; default: } }, false);
四、
function GetSlideDirection(startX, startY, endX, endY) { var dy = startY - endY; //var dx = endX - startX; var result = 0; if(dy>0) {//向上滑動(dòng) result=1; }else if(dy<0){//向下滑動(dòng) result=2; } else { result=0; } return result; }
總結(jié)
以上所述是小編給大家介紹的JS實(shí)現(xiàn)移動(dòng)端判斷上拉和下滑功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- js判斷瀏覽器的環(huán)境(pc端,移動(dòng)端,還是微信瀏覽器)
- 移動(dòng)端使用CSS或JS判斷橫屏和豎屏的講解
- 使用JS判斷移動(dòng)端手機(jī)橫豎屏狀態(tài)
- js判斷PC端與移動(dòng)端跳轉(zhuǎn)
- js簡(jiǎn)單判斷移動(dòng)端系統(tǒng)的方法
- js判斷移動(dòng)端是否安裝某款app的多種方法
- JavaScript判斷手機(jī)號(hào)運(yùn)營(yíng)商是移動(dòng)、聯(lián)通、電信還是其他(代碼簡(jiǎn)單)
- js如何判斷用戶是在PC端和還是移動(dòng)端訪問(wèn)
- JS實(shí)現(xiàn)判斷移動(dòng)端PC端功能
相關(guān)文章
js獲取上傳文件的絕對(duì)路徑實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇js獲取上傳文件的絕對(duì)路徑實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08JavaScript和Vue分別實(shí)現(xiàn)逐字彈出(打字機(jī))效果
這篇文章主要為大家詳細(xì)介紹了如何通過(guò)CSS、JavaScript和Vue分別實(shí)現(xiàn)逐字彈出(打字機(jī))效果,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考一下2024-01-01JavaScript中的this/call/apply/bind的使用及區(qū)別
這篇文章主要介紹了JavaScript中的this/call/apply/bind的使用及區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-031分鐘快速了解js實(shí)現(xiàn)下載文件功能的4種方式
在前端開(kāi)發(fā)中,我們經(jīng)常需要實(shí)現(xiàn)文件下載功能,例如下載用戶上傳的圖片、用戶生成的文件等,這篇文章主要給大家介紹了關(guān)于如何通過(guò)1分鐘快速了解js實(shí)現(xiàn)下載文件功能的4種方式,需要的朋友可以參考下2024-03-03javascript sort()對(duì)數(shù)組中的元素進(jìn)行排序詳解
在本篇文章里小編給大家整理是一篇關(guān)于javascript sort()對(duì)數(shù)組中的元素進(jìn)行排序的相關(guān)知識(shí)點(diǎn)內(nèi)容,需要的朋友們學(xué)習(xí)下。2019-10-10