91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS移動端實現拖拽的方法

發布時間:2020-10-28 21:14:18 來源:億速云 閱讀:204 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關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 的時候,元素有明顯的閃動

看完上述內容,你們對JS移動端實現拖拽的方法有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

js
AI

南澳县| 西丰县| 洛川县| 定远县| 奉新县| 侯马市| 会理县| 新巴尔虎右旗| 泾阳县| 谢通门县| 平原县| 霍邱县| 栾城县| 曲松县| 镇江市| 池州市| 万载县| 苍溪县| 桦南县| 沛县| 靖边县| 彰化市| 吉安市| 麟游县| 白水县| 简阳市| 越西县| 阜南县| 涿鹿县| 珲春市| 荆州市| 牡丹江市| 青海省| 石屏县| 太和县| 青龙| 昌邑市| 伊通| 菏泽市| 汉中市| 东港市|