亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

阻止移動端touchmove與scroll事件沖突技巧

 更新時間:2023年06月14日 09:47:29   作者:天問  
這篇文章主要為大家介紹了阻止移動端touchmove與scroll事件沖突技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

正文

在移動端開發(fā)過程中,如果要實現(xiàn)一個元素或按鈕的拖動定位,會出現(xiàn)很多坑。例如:元素上下移動過程中,會觸發(fā) bodyscroll 事件,導(dǎo)致整體的位置偏移,這時就需要 阻止移動端 touchmove 與 scroll 事件沖突 。

DOM Touchmove Scroll

一、解決思路

  • 當(dāng)移動端 touchmove 與 scroll 事件沖突時,首先想到的就是在 touchmove 事件監(jiān)聽過程中阻止默認(rèn)事件(e.preventDefault())。
  • 如果你這樣做了,緊接著你就會看到控制臺的報錯:[Intervention] Unable to preventDefault inside passive event listener due to target being treated as passive.
  • 然后通過 MDN ,得知 addEventListener 方法的第三個參數(shù) options 有很多可選配置。
  • options 是一個指定有關(guān) listener 屬性的可選參數(shù)對象??捎玫倪x項如下:
參數(shù)定義
capture一個布爾值,表示 listener 會在該類型的事件捕獲階段傳播到該 EventTarget 時觸發(fā)。
once一個布爾值,表示 listener 在添加之后最多只調(diào)用一次。如果為 true,listener 會在其被調(diào)用之后自動移除。
passive一個布爾值,設(shè)置為 true 時,表示 listener 永遠(yuǎn)不會調(diào)用 preventDefault()。如果 listener 仍然調(diào)用了這個函數(shù),客戶端將會忽略它并拋出一個控制臺警告。查看 使用 passive 改善滾屏性能以了解更多
signalAbortSignal,該 AbortSignalabort() 方法被調(diào)用時,監(jiān)聽器會被移除。

二、問題所在

因為將 passive 設(shè)為 true 可以啟用性能優(yōu)化,并可大幅改善應(yīng)用性能,所以大部分瀏覽器(Safari 和 Internet Explorer 除外)將文檔級節(jié)點(diǎn) Window、Document 和 Document.body 上的 wheel、mousewheel、touchstart 和 touchmove 事件的 passive 默認(rèn)值更改為 true 。如此,事件監(jiān)聽器便不能取消事件,也不會在用戶滾動頁面時阻止頁面呈現(xiàn)。

因此,當(dāng)你想要覆蓋這一行為并確認(rèn) passive 在所有瀏覽器中都被設(shè)為 false,你必須顯式地將其設(shè)為 false,而不是依賴瀏覽器的默認(rèn)設(shè)置。

  • 關(guān)鍵代碼:
document.addEventListener('touchmove', touchmove, {
  passive: false,
})
function touchmove(e) {
  e = e || window.event
  // do something
  e.preventDefault()
}

參考文檔:

以上就是阻止移動端touchmove與scroll事件沖突技巧的詳細(xì)內(nèi)容,更多關(guān)于阻止touchmove與scroll沖突的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 淺析js中的浮點(diǎn)型運(yùn)算問題

    淺析js中的浮點(diǎn)型運(yùn)算問題

    本篇文章主要是對js中浮點(diǎn)型運(yùn)算的問題進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • H5實現(xiàn)仿flash效果的實現(xiàn)代碼

    H5實現(xiàn)仿flash效果的實現(xiàn)代碼

    這篇文章主要介紹了H5實現(xiàn)仿flash效果的實現(xiàn)代碼的相關(guān)資料,希望通過本文能幫助到大家,實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-09-09
  • js實現(xiàn)車輛管理系統(tǒng)

    js實現(xiàn)車輛管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了js實現(xiàn)車輛管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 基于JavaScript實現(xiàn)購物網(wǎng)站商品放大鏡效果

    基于JavaScript實現(xiàn)購物網(wǎng)站商品放大鏡效果

    大家在日常生活中都有網(wǎng)購的經(jīng)驗,有的網(wǎng)站會有商品放大鏡功能,效果非常棒,那么基于js代碼是如何實現(xiàn)的呢?下面小編給大家?guī)砹嘶趈s實現(xiàn)購物網(wǎng)站商品放大鏡效果,非常不錯,感興趣的朋友參考下吧
    2016-09-09
  • 利用JS判斷字符串是否含有數(shù)字與特殊字符的方法小結(jié)

    利用JS判斷字符串是否含有數(shù)字與特殊字符的方法小結(jié)

    在我們?nèi)粘9ぷ鞯臅r候,利用javaScript判斷一個字符串中是否包括有數(shù)字和"-",在一些表單提交的地方,這是比較有用的常規(guī)判斷,這里收集有幾種不同的方法,最后還將簡要介紹下isNAN函數(shù)的使用方法和例子,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-11-11
  • JavaScript中的this實例分析

    JavaScript中的this實例分析

    做web開發(fā)幾年,也認(rèn)為自己的js寫了不少,可真正去解釋這個東西的時候,才發(fā)現(xiàn)不是這么簡單,花了一些時間,寫了幾個小demo,讓我們來一探究竟。
    2011-04-04
  • javascript實現(xiàn)雪花飄落效果

    javascript實現(xiàn)雪花飄落效果

    這篇文章主要為大家詳細(xì)介紹了javascript實現(xiàn)雪花飄落效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 使用JavaScript實現(xiàn)檢測網(wǎng)頁是否為空閑狀態(tài)

    使用JavaScript實現(xiàn)檢測網(wǎng)頁是否為空閑狀態(tài)

    最近開發(fā)項目時,常碰到“用戶在一定時間內(nèi)無任何操作時,跳轉(zhuǎn)到某個頁面”的需求,所以本文就來使用JavaScript實現(xiàn)這一要求,需要的可以參考下
    2024-03-03
  • 微信小程序--特定區(qū)域滾動到頂部時固定的方法

    微信小程序--特定區(qū)域滾動到頂部時固定的方法

    這篇文章主要介紹了微信小程序--特定區(qū)域滾動到頂部時固定的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • JavaScript函數(shù)綁定用法實例分析

    JavaScript函數(shù)綁定用法實例分析

    這篇文章主要介紹了JavaScript函數(shù)綁定用法,結(jié)合實例形式分析了javascript函數(shù)綁定的原理、實現(xiàn)方法與相關(guān)操作技巧,需要的朋友可以參考下
    2017-11-11

最新評論