成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

移動端h5模擬長按事件

李昌杰 / 1903人閱讀

摘要:為啥寫這篇文章最近接了個需求,要求長按某個標(biāo)簽顯示刪除一個懸浮的刪除按鈕。這個需求其實(shí)在上很常見,但是在移動端中,我們沒有長按的事件,所以就需要自己模擬這個事件了。由此我們可以實(shí)現(xiàn)模擬的長按事件了。

為啥寫這篇文章

最近接了個需求,要求長按某個標(biāo)簽顯示刪除一個懸浮的刪除按鈕。這個需求其實(shí)在app上很常見,但是在移動端h5中,我們沒有長按的事件,所以就需要自己模擬這個事件了。

大概效果如下:

ps: 為了做個gif還下了app,還得通過郵件發(fā)到電腦上,腦瓜疼。。

思路

放棄click事件,通過判斷按的時(shí)長來決定是單擊還是長按

使用touchstart和touchend事件

在touchstart中開啟一個定時(shí)器,比如在700ms后顯示一個長按菜單

在touchend中清除這個定時(shí)器,這樣如果按下的時(shí)間超過700ms,那么長按菜單已經(jīng)顯示出來了,清除定時(shí)器不會有任何影響;如果按下的時(shí)間小于700ms,那么touchstart中的長按菜單還沒來得及顯示出來,就被清除了。

由此我們可以實(shí)現(xiàn)模擬的長按事件了。

上代碼

請把重點(diǎn)放在JS上,這里貼出來完整的代碼是為了方便大家看個仔細(xì),代碼可以拷貝直接看效果
css中大部分只是做了樣式的美化,還有一開始讓刪除按鈕隱藏起來

HTML:



    
    
    
    Document
    


    
長按我
刪除
JS
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只有在移動端設(shè)備上才有用,如果要看代碼示例的話請:

用chrome

F12打開調(diào)時(shí)窗

切換到模擬移動設(shè)備

即點(diǎn)擊如下圖:

最后

歡迎交流~

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98073.html

相關(guān)文章

  • 移動h5模擬長按事件

    摘要:為啥寫這篇文章最近接了個需求,要求長按某個標(biāo)簽顯示刪除一個懸浮的刪除按鈕。這個需求其實(shí)在上很常見,但是在移動端中,我們沒有長按的事件,所以就需要自己模擬這個事件了。由此我們可以實(shí)現(xiàn)模擬的長按事件了。 為啥寫這篇文章 最近接了個需求,要求長按某個標(biāo)簽顯示刪除一個懸浮的刪除按鈕。這個需求其實(shí)在app上很常見,但是在移動端h5中,我們沒有長按的事件,所以就需要自己模擬這個事件了。 大概效果如...

    付倫 評論0 收藏0
  • 原生js實(shí)現(xiàn)移動點(diǎn)擊、長按、左滑、右滑、上滑、下滑等事件模擬

    摘要:原理如下監(jiān)聽的和事件。代表的絕對值,左右滑動,右滑,反之左滑。代碼如下用事件模擬點(diǎn)擊左滑右滑上拉下拉等時(shí)間,是利用和兩個事件發(fā)生的位置來確定是什么操作。支持六個事件是左滑事件,是右滑事件,是上滑事件,下滑事件,點(diǎn)擊事件,長按點(diǎn)擊事件。 github地址:https://github.com/xubaodian/...為什么要模擬這些事件?1、上述這些事件中,瀏覽器直接支持的事件只有點(diǎn)擊...

    WrBug 評論0 收藏0
  • 移動頁面功能之------長按事件

    摘要:有時(shí)在做移動端頁面開發(fā)過程中遇到這種需求模擬指紋識別。實(shí)際上我們只能通過長按頁面中的元素來模擬這個功能。在和中都沒有包含長按事件,所以需要我們來擴(kuò)展一下。 有時(shí)在做移動端頁面開發(fā)過程中遇到這種需求:模擬指紋識別。實(shí)際上我們只能通過長按頁面中的元素來模擬這個功能。在jQuery和Zepto中都沒有包含長按事件,所以需要我們來擴(kuò)展一下。 $.fn.longPress = function(...

    sf_wangchong 評論0 收藏0
  • 移動VUE點(diǎn)擊、滑動和長按事件處理(自定義指令)

    摘要:問題移動設(shè)備上的觸摸事件如何利用它們?nèi)齻€來處理點(diǎn)擊長按滑動等操作,以及如何在測試用例中模擬它們的操作參考了實(shí)現(xiàn)方法上這位大哥的思路移動設(shè)備的點(diǎn)擊優(yōu)化參考了感謝解決使用自定義指令來干這件事來記錄開始點(diǎn)擊的位置和時(shí)間,并在這里邊判斷長按操作來確 問題: 移動設(shè)備上的觸摸事件:touchstart、touchmove、touchend如何利用它們?nèi)齻€來處理點(diǎn)擊、長按、滑動等操作,以及如何在測...

    niuxiaowei111 評論0 收藏0
  • 移動h5開發(fā)總結(jié)不斷更新中....

    摘要:一手機(jī)端開發(fā)頁面必須要加一段代碼注這段代碼的主要意思是讓頁面寬度等于設(shè)備寬度,縮放比例為,禁止用戶縮放。用于檢測視口,主要的效果就是取消下面的滾動條,讓頁面適應(yīng)屏幕。 一.手機(jī)端開發(fā)頁面必須要加一段代碼: 注:這段代碼的主要意思是:讓頁面寬度等于設(shè)備寬度,縮放比例為1,禁止用戶縮放。用于檢測視口,主要的效果就是取消下面的滾動條,讓頁面適應(yīng)屏幕。 二.為自己的頁面設(shè)置最大寬度和最小寬...

    kviccn 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<