日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

移動端JS實現拖拽兩種方法解析

瀏覽:170日期:2024-04-17 11:21:44

移動端的項目經常會引入手勢庫來實現拖拽

不過如果只是一兩個頁面用到拖拽,再引入一個手勢庫就很不劃算

最近的項目中就有這么一個需求:

移動端JS實現拖拽兩種方法解析

因為就這一個地方需要拖拽,所以我就沒有引入第三方庫

移動端的拖拽有兩種主流的實現方案:

1. 將元素設置為固定定位,然后在拖拽的時候修改其定位,實現拖拽的效果;

2. 使用 transform 中的平移translate 屬性實現拖拽。

方案一:固定定位 fixed

這種方案的核心就是給元素添加固定定位position:fixed;

但定位之后,元素會脫離文檔流,會影響原有但布局

因此在開始拖拽 (觸發touchstart事件) 的時候,需要將原本的元素 A 拷貝一份 (cloneNode())

給新元素 A2 添加定位,同時給原本的元素 A 設置visibility:hidden; 使之隱藏并占位

1.1 創建遮罩

首先封裝一個創建遮罩的方法,用于放置拷貝出來的元素,并防止誤觸

createModal (id) { let modal = document.getElementById(id) if (!modal) { // 在沒有遮罩的時候創建遮罩 modal = document.createElement(’div’) modal.id = id modal.style.cssText = `position: fixed; left: 0; top: 0; right: 0; bottom: 0; z-index: 999;` document.body.appendChild(modal) }},

1.2 開始拖拽

在觸發touchstart事件的時候,首先創建遮罩

并通過getBoundingClientRect()方法獲取到元素 A 的坐標,記錄起點信息

為了記錄起點信息,需要 data 中創建一個對象source,用于記錄點擊的位置 client,和初始定位坐標 start

handleTouchstart (e) { // 開始拖拽 // 創建遮罩層 this.createModal(this.modalID) // modalID 遮罩層的id,由外部定義 let element = e.targetTouches[0] let target = e.target.cloneNode(true) // 拷貝目標元素 target.id = this.copyID // copyID 拷貝元素的id,由外部定義 // 記錄初始點擊位置 client,用于計算移動距離 this.source.client = { x: element.clientX, y: element.clientY } // 算出目標元素的固定位置 let disX = this.source.start.left = element.target.getBoundingClientRect().left let disY = this.source.start.top = element.target.getBoundingClientRect().top target.style.cssText = `position: fixed; left: ${disX}px; top: ${disY}px;` // 將拷貝的元素放到遮罩中 document.getElementById(this.modalID).appendChild(target)},

1.3 處理拖拽

拖拽的時候,監聽touchmove事件

用【當前鼠標點位置】減去【初始點擊位置】得到移動的距離

再結合初始坐標信息,更新拖拽元素的坐標

handleTouchmove (e) { // 拖拽中 let element = e.targetTouches[0] let target = document.getElementById(this.copyID) // 根據初始點擊位置 client 計算移動距離 let left = this.source.start.left + element.clientX - this.source.client.x let top = this.source.start.top + element.clientY - this.source.client.y // 移動當前元素 target.style.left = `${left}px` target.style.top = `${top}px`},

1.4 拖拽結束

拖拽結束的時候,記錄終點位置,刪除遮罩

handleTouchend (e) { // 拖拽結束 let end = { x: e.changedTouches[0].clientX, y: e.changedTouches[0].clientY } // 刪除遮罩層 let modal = document.getElementById(this.modalID) document.body.removeChild(modal) // 處理結果 this.doingSth(end)},

不過上面的代碼只實現了拖拽的功能,并沒有對目標元素 A 進行顯示/隱藏的操作

可以根據業務場景自行添加,或者參考方案二

方案二:平移動畫translate

這種方案更為簡單,不需要創建額外的 DOM 元素

只需對原本的元素添加 transform 屬性,甚至不需要 transition 屬性

然后在拖拽過程中,實時更新transform: translate(X, Y)中 x, y 的坐標信息,實現拖拽

2.1 開始拖拽

開始拖拽的時候,只需要記錄起點坐標

handleTouchstart (e) { // 開始拖拽 let element = e.targetTouches[0]// 記錄初始 client 位置,用于計算移動距離 this.source.client = { x: element.clientX, y: element.clientY }},

為了防止拖拽的過程中誤觸,建議使用方案一的createModal()方法創建一個遮罩

2.2 處理拖拽

根據當前坐標和起點坐標,計算出距離,然后更新 translate 的坐標

handleTouchmove (e) { // 拖拽中 let element = e.targetTouches[0] // 根據初始 client 位置計算移動距離 let x = element.clientX - this.source.client.x let y = element.clientY - this.source.client.y // 移動當前元素 element.target.style.cssText = `transform: translate(${x}px, ${y}px);`},

2.3 拖拽結束

拖拽完成后,清除平移動畫

handleTouchend (e) { // 拖拽結束 // 清除拖拽樣式 e.target.style.cssText = `transform: none;`},

小結:

方案一在獲取目標元素的坐標信息的時候使用了 getBoundingClientRect() 方法

但這個方法性能不高,應當少用

而且即時使用了該方法,最后得到的 left 和 top 也不夠精確,touchstart 的時候,元素有明顯的閃動

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精选成人| 青青草视频一区| 青草久久视频| 色老板在线视频一区二区| 国产精品一区二区美女视频免费看 | 国产高清不卡| 亚洲中字黄色| 亚洲精品成人| 激情欧美丁香| 精品一区二区三区中文字幕在线| 日韩成人精品一区二区三区| 香蕉久久国产| 亚洲精品大全| 欧美天堂在线| 亚洲一区二区三区四区五区午夜| 亚洲欧美综合| 午夜精品亚洲| 欧美日韩国产在线一区| 免费欧美一区| 欧洲av一区二区| 亚洲小说春色综合另类电影| 国产视频久久| 国产欧美三级| 免费成人网www| 少妇精品久久久| 色婷婷狠狠五月综合天色拍| 啪啪亚洲精品| 在线成人动漫av| 欧美亚洲网站| 日本不卡免费高清视频在线| 亚洲尤物av| 麻豆视频久久| 日韩成人精品一区| 蜜臀av国产精品久久久久| 麻豆精品一区二区综合av| 99精品在线| 日韩精品视频在线看| 久久精品理论片| 综合国产精品| 日韩欧美字幕| 日韩av电影一区| 日本午夜精品视频在线观看| 国产高清日韩| 石原莉奈在线亚洲二区| 精品三级国产| 欧美精品黄色| 日韩av专区| 国产精品3区| 日韩视频不卡| 麻豆国产欧美日韩综合精品二区| 欧美亚洲二区| 亚洲小说欧美另类婷婷| 国产欧美二区| 噜噜噜久久亚洲精品国产品小说| 久久精品主播| 久久精品国产亚洲aⅴ| 国内精品福利| 精品视频自拍| 日韩中出av| 亚洲最新av| 国语对白精品一区二区| 日韩欧美中文字幕电影 | 欧美日韩夜夜| 免费美女久久99| 卡一卡二国产精品| 97久久精品| 欧美激情视频一区二区三区免费| 亚洲欧美网站在线观看| 久久久天天操| 精品三级在线观看视频| 最新亚洲一区| 婷婷成人基地| 久久久久国产精品一区三寸| 麻豆精品视频在线观看| 欧美在线不卡| 综合激情视频| 亚洲三区欧美一区国产二区| 男人的天堂久久精品| 国产成人精品免费视| 美女精品一区| 蜜桃视频一区二区三区在线观看| 亚洲资源av| 红桃视频国产精品| 激情久久中文字幕| 老司机精品视频网| 国产日产精品_国产精品毛片 | 亚洲一区二区日韩| 久久九九国产| 99在线观看免费视频精品观看| 久久久夜精品| 久久精品国产亚洲夜色av网站| 日韩极品在线观看| 中文字幕一区二区三区日韩精品| 日韩午夜在线| 羞羞答答国产精品www一本| 亚洲一级影院| 国产成人久久精品麻豆二区 | 视频一区二区欧美| 亚洲精品婷婷| 视频一区二区中文字幕| 蜜桃视频欧美| 中文在线а√在线8| 成人国产综合| 新版的欧美在线视频| 日韩一区电影| 久久国产电影| 99久久久久| 在线亚洲精品| 久久精品二区三区| 国产精品中文| 久久中文字幕一区二区三区| 国产精品国产三级国产在线观看| 91欧美在线| 91精品韩国| 午夜精品一区二区三区国产| 亚洲福利一区| 亚洲激情中文在线| 综合激情五月婷婷| 国产精品美女在线观看直播| 亚洲影院天堂中文av色| av一区二区高清| 国产精品日本| 亚洲乱码视频| 久久99久久人婷婷精品综合| 福利一区视频| 国产精品麻豆成人av电影艾秋| 蜜臀精品一区二区三区在线观看 | 四虎国产精品免费观看| 久久久久欧美精品| 日韩av一区二区在线影视| 精品国产网站| 精品伊人久久| 欧美日韩少妇| 日韩av电影一区| 免费高潮视频95在线观看网站| 国产aⅴ精品一区二区三区久久| 99久久99久久精品国产片果冰| 午夜性色一区二区三区免费视频| 亚洲欧美一级| 亚洲综合在线电影| 欧美日韩视频一区二区三区| 99久久夜色精品国产亚洲狼| 日韩中文字幕麻豆| 国产精品久久久久久久久久妞妞| 麻豆精品视频在线| 国产精品片aa在线观看| 日韩在线综合| 日韩精品视频在线看| av资源新版天堂在线| 欧美va天堂| 91成人网在线观看| 欧美在线精品一区| 久久香蕉国产| 国产丝袜一区| 久久久久美女| 在线精品福利| 成人va天堂| 日韩黄色在线观看| 国产精品久久久亚洲一区| 亚洲播播91| 国产精品v一区二区三区| 婷婷综合网站| 亚洲深深色噜噜狠狠爱网站| 日韩成人a**站| 欧美日韩一区自拍| 99热国内精品| 蜜桃免费网站一区二区三区| 国产不卡精品| 日韩制服丝袜av| 欧美男人天堂| 婷婷成人综合| 国产精品xxx在线观看| 老色鬼久久亚洲一区二区| 精品国产亚洲一区二区三区在线| 亚洲免费中文| 日本视频在线一区| 国精品一区二区| 精品久久免费| 国产福利亚洲| 日韩视频二区| 国产99久久| 国产精品99一区二区三区| 色狠狠一区二区三区| 久久成人福利| 免费成人性网站| 久久三级福利| 国产一区二区三区日韩精品| 国产一区久久| 日韩手机在线| 久久影院一区二区三区| 亚洲综合国产| 国产一区亚洲| 91日韩欧美| 美女精品网站| 99riav国产精品| 91精品国产乱码久久久久久久| 日韩一区网站| 国产亚洲毛片在线| 婷婷亚洲五月| 日本va欧美va精品|