欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

阻止移動(dòng)端touchmove與scroll事件沖突技巧

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

正文

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

DOM Touchmove Scroll

一、解決思路

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

二、問題所在

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

參考文檔:

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

    JavaScript中的this實(shí)例分析

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

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

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

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

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

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

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

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

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

最新評(píng)論