国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

移動(dòng)端h5模擬長(zhǎng)按事件

付倫 / 2289人閱讀

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

為啥寫(xiě)這篇文章

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

大概效果如下:

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

思路

放棄click事件,通過(guò)判斷按的時(shí)長(zhǎng)來(lái)決定是單擊還是長(zhǎng)按

使用touchstart和touchend事件

在touchstart中開(kāi)啟一個(gè)定時(shí)器,比如在700ms后顯示一個(gè)長(zhǎng)按菜單

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

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

上代碼

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

HTML:



    
    
    
    Document
    


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

用chrome

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

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

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

最后

歡迎交流~

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/53004.html

相關(guān)文章

  • 移動(dòng)h5模擬長(zhǎng)按事件

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

    李昌杰 評(píng)論0 收藏0
  • 原生js實(shí)現(xiàn)移動(dòng)點(diǎn)擊、長(zhǎng)按、左滑、右滑、上滑、下滑等事件模擬

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

    WrBug 評(píng)論0 收藏0
  • 移動(dòng)頁(yè)面功能之------長(zhǎng)按事件

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

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

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

    niuxiaowei111 評(píng)論0 收藏0
  • 移動(dòng)h5開(kāi)發(fā)總結(jié)不斷更新中....

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

    kviccn 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<