摘要:為啥寫這篇文章最近接了個(gè)需求,要求長按某個(gè)標(biāo)簽顯示刪除一個(gè)懸浮的刪除按鈕。這個(gè)需求其實(shí)在上很常見,但是在移動(dòng)端中,我們沒有長按的事件,所以就需要自己模擬這個(gè)事件了。由此我們可以實(shí)現(xiàn)模擬的長按事件了。
為啥寫這篇文章
最近接了個(gè)需求,要求長按某個(gè)標(biāo)簽顯示刪除一個(gè)懸浮的刪除按鈕。這個(gè)需求其實(shí)在app上很常見,但是在移動(dòng)端h5中,我們沒有長按的事件,所以就需要自己模擬這個(gè)事件了。
大概效果如下:
ps: 為了做個(gè)gif還下了app,還得通過郵件發(fā)到電腦上,腦瓜疼。。
思路放棄click事件,通過判斷按的時(shí)長來決定是單擊還是長按
使用touchstart和touchend事件
在touchstart中開啟一個(gè)定時(shí)器,比如在700ms后顯示一個(gè)長按菜單
在touchend中清除這個(gè)定時(shí)器,這樣如果按下的時(shí)間超過700ms,那么長按菜單已經(jīng)顯示出來了,清除定時(shí)器不會(huì)有任何影響;如果按下的時(shí)間小于700ms,那么touchstart中的長按菜單還沒來得及顯示出來,就被清除了。
由此我們可以實(shí)現(xiàn)模擬的長按事件了。
上代碼請(qǐng)把重點(diǎn)放在JS上,這里貼出來完整的代碼是為了方便大家看個(gè)仔細(xì),代碼可以拷貝直接看效果
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) { // 處理點(diǎn)擊事件 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只有在移動(dòng)端設(shè)備上才有用,如果要看代碼示例的話請(qǐng):
用chrome
F12打開調(diào)時(shí)窗
切換到模擬移動(dòng)設(shè)備
即點(diǎn)擊如下圖:
最后歡迎交流~
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/53004.html
摘要:為啥寫這篇文章最近接了個(gè)需求,要求長按某個(gè)標(biāo)簽顯示刪除一個(gè)懸浮的刪除按鈕。這個(gè)需求其實(shí)在上很常見,但是在移動(dòng)端中,我們沒有長按的事件,所以就需要自己模擬這個(gè)事件了。由此我們可以實(shí)現(xiàn)模擬的長按事件了。 為啥寫這篇文章 最近接了個(gè)需求,要求長按某個(gè)標(biāo)簽顯示刪除一個(gè)懸浮的刪除按鈕。這個(gè)需求其實(shí)在app上很常見,但是在移動(dòng)端h5中,我們沒有長按的事件,所以就需要自己模擬這個(gè)事件了。 大概效果如...
摘要:原理如下監(jiān)聽的和事件。代表的絕對(duì)值,左右滑動(dòng),右滑,反之左滑。代碼如下用事件模擬點(diǎn)擊左滑右滑上拉下拉等時(shí)間,是利用和兩個(gè)事件發(fā)生的位置來確定是什么操作。支持六個(gè)事件是左滑事件,是右滑事件,是上滑事件,下滑事件,點(diǎn)擊事件,長按點(diǎn)擊事件。 github地址:https://github.com/xubaodian/...為什么要模擬這些事件?1、上述這些事件中,瀏覽器直接支持的事件只有點(diǎn)擊...
摘要:有時(shí)在做移動(dòng)端頁面開發(fā)過程中遇到這種需求模擬指紋識(shí)別。實(shí)際上我們只能通過長按頁面中的元素來模擬這個(gè)功能。在和中都沒有包含長按事件,所以需要我們來擴(kuò)展一下。 有時(shí)在做移動(dòng)端頁面開發(fā)過程中遇到這種需求:模擬指紋識(shí)別。實(shí)際上我們只能通過長按頁面中的元素來模擬這個(gè)功能。在jQuery和Zepto中都沒有包含長按事件,所以需要我們來擴(kuò)展一下。 $.fn.longPress = function(...
摘要:問題移動(dòng)設(shè)備上的觸摸事件如何利用它們?nèi)齻€(gè)來處理點(diǎn)擊長按滑動(dòng)等操作,以及如何在測(cè)試用例中模擬它們的操作參考了實(shí)現(xiàn)方法上這位大哥的思路移動(dòng)設(shè)備的點(diǎn)擊優(yōu)化參考了感謝解決使用自定義指令來干這件事來記錄開始點(diǎn)擊的位置和時(shí)間,并在這里邊判斷長按操作來確 問題: 移動(dòng)設(shè)備上的觸摸事件:touchstart、touchmove、touchend如何利用它們?nèi)齻€(gè)來處理點(diǎn)擊、長按、滑動(dòng)等操作,以及如何在測(cè)...
摘要:一手機(jī)端開發(fā)頁面必須要加一段代碼注這段代碼的主要意思是讓頁面寬度等于設(shè)備寬度,縮放比例為,禁止用戶縮放。用于檢測(cè)視口,主要的效果就是取消下面的滾動(dòng)條,讓頁面適應(yīng)屏幕。 一.手機(jī)端開發(fā)頁面必須要加一段代碼: 注:這段代碼的主要意思是:讓頁面寬度等于設(shè)備寬度,縮放比例為1,禁止用戶縮放。用于檢測(cè)視口,主要的效果就是取消下面的滾動(dòng)條,讓頁面適應(yīng)屏幕。 二.為自己的頁面設(shè)置最大寬度和最小寬...
閱讀 4915·2021-10-13 09:39
閱讀 1971·2019-08-29 11:12
閱讀 1161·2019-08-28 18:16
閱讀 1873·2019-08-26 12:16
閱讀 1260·2019-08-26 12:13
閱讀 3006·2019-08-26 10:59
閱讀 2315·2019-08-23 18:27
閱讀 3004·2019-08-23 18:02