摘要:為啥寫這篇文章最近接了個需求,要求長按某個標簽顯示刪除一個懸浮的刪除按鈕。這個需求其實在上很常見,但是在移動端中,我們沒有長按的事件,所以就需要自己模擬這個事件了。由此我們可以實現模擬的長按事件了。
為啥寫這篇文章
最近接了個需求,要求長按某個標簽顯示刪除一個懸浮的刪除按鈕。這個需求其實在app上很常見,但是在移動端h5中,我們沒有長按的事件,所以就需要自己模擬這個事件了。
大概效果如下:
ps: 為了做個gif還下了app,還得通過郵件發到電腦上,腦瓜疼。。
思路放棄click事件,通過判斷按的時長來決定是單擊還是長按
使用touchstart和touchend事件
在touchstart中開啟一個定時器,比如在700ms后顯示一個長按菜單
在touchend中清除這個定時器,這樣如果按下的時間超過700ms,那么長按菜單已經顯示出來了,清除定時器不會有任何影響;如果按下的時間小于700ms,那么touchstart中的長按菜單還沒來得及顯示出來,就被清除了。
由此我們可以實現模擬的長按事件了。
上代碼請把重點放在JS上,這里貼出來完整的代碼是為了方便大家看個仔細,代碼可以拷貝直接看效果
css中大部分只是做了樣式的美化,還有一開始讓刪除按鈕隱藏起來
JSDocument 長按我刪除
let timer = null let startTime = "" let endTime = "" const label = document.querySelector(".label") const deleteBtn = document.querySelector(".delete_btn") label.addEventListener("touchstart", function () { startTime = +new Date() timer = setTimeout(function () { deleteBtn.style.display = "block" }, 700) }) label.addEventListener("touchend", function () { endTime = +new Date() clearTimeout(timer) if (endTime - startTime < 700) { // 處理點擊事件 label.classList.add("selected") } })CSS
.container { position: relative; display: inline-block; margin-top: 50px; } .label { display: inline-block; box-sizing: border-box; width: 105px; height: 32px; line-height: 32px; background-color: #F2F2F2; color: #5F5F5F; text-align: center; border-radius: 3px; font-size: 14px; } .label.selected { background-color: #4180cc; color: white; } .delete_btn { display: none; position: absolute; top: -8px; left: 50%; transform: translateX(-50%) translateY(-100%); color: white; padding: 10px 16px; background-color: rgba(0, 0, 0, .7); border-radius: 6px; line-height: 1; white-space: nowrap; font-size: 12px; } .delete_btn::after { content: ""; width: 0; height: 0; border-width: 5px; border-style: solid; border-color: rgba(0, 0, 0, .7) transparent transparent transparent; position: absolute; bottom: -9px; left: 50%; transform: translateX(-50%); }
ps: touchstart和touchend只有在移動端設備上才有用,如果要看代碼示例的話請:
用chrome
F12打開調時窗
切換到模擬移動設備
即點擊如下圖:
最后歡迎交流~
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/98073.html
摘要:為啥寫這篇文章最近接了個需求,要求長按某個標簽顯示刪除一個懸浮的刪除按鈕。這個需求其實在上很常見,但是在移動端中,我們沒有長按的事件,所以就需要自己模擬這個事件了。由此我們可以實現模擬的長按事件了。 為啥寫這篇文章 最近接了個需求,要求長按某個標簽顯示刪除一個懸浮的刪除按鈕。這個需求其實在app上很常見,但是在移動端h5中,我們沒有長按的事件,所以就需要自己模擬這個事件了。 大概效果如...
摘要:原理如下監聽的和事件。代表的絕對值,左右滑動,右滑,反之左滑。代碼如下用事件模擬點擊左滑右滑上拉下拉等時間,是利用和兩個事件發生的位置來確定是什么操作。支持六個事件是左滑事件,是右滑事件,是上滑事件,下滑事件,點擊事件,長按點擊事件。 github地址:https://github.com/xubaodian/...為什么要模擬這些事件?1、上述這些事件中,瀏覽器直接支持的事件只有點擊...
摘要:有時在做移動端頁面開發過程中遇到這種需求模擬指紋識別。實際上我們只能通過長按頁面中的元素來模擬這個功能。在和中都沒有包含長按事件,所以需要我們來擴展一下。 有時在做移動端頁面開發過程中遇到這種需求:模擬指紋識別。實際上我們只能通過長按頁面中的元素來模擬這個功能。在jQuery和Zepto中都沒有包含長按事件,所以需要我們來擴展一下。 $.fn.longPress = function(...
摘要:問題移動設備上的觸摸事件如何利用它們三個來處理點擊長按滑動等操作,以及如何在測試用例中模擬它們的操作參考了實現方法上這位大哥的思路移動設備的點擊優化參考了感謝解決使用自定義指令來干這件事來記錄開始點擊的位置和時間,并在這里邊判斷長按操作來確 問題: 移動設備上的觸摸事件:touchstart、touchmove、touchend如何利用它們三個來處理點擊、長按、滑動等操作,以及如何在測...
摘要:一手機端開發頁面必須要加一段代碼注這段代碼的主要意思是讓頁面寬度等于設備寬度,縮放比例為,禁止用戶縮放。用于檢測視口,主要的效果就是取消下面的滾動條,讓頁面適應屏幕。 一.手機端開發頁面必須要加一段代碼: 注:這段代碼的主要意思是:讓頁面寬度等于設備寬度,縮放比例為1,禁止用戶縮放。用于檢測視口,主要的效果就是取消下面的滾動條,讓頁面適應屏幕。 二.為自己的頁面設置最大寬度和最小寬...
閱讀 2074·2021-11-15 17:57
閱讀 739·2021-11-11 16:54
閱讀 2589·2021-09-27 13:58
閱讀 4067·2021-09-06 15:00
閱讀 950·2021-09-04 16:45
閱讀 3505·2019-08-30 15:56
閱讀 1784·2019-08-30 15:53
閱讀 1604·2019-08-30 14:12