阻止移動端touchmove與scroll事件沖突技巧
正文
在移動端開發(fā)過程中,如果要實現(xiàn)一個元素或按鈕的拖動定位,會出現(xiàn)很多坑。例如:元素上下移動過程中,會觸發(fā) body 的 scroll 事件,導(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 改善滾屏性能以了解更多。 |
signal | AbortSignal,該 AbortSignal 的 abort() 方法被調(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)文章
基于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é)
在我們?nèi)粘9ぷ鞯臅r候,利用javaScript判斷一個字符串中是否包括有數(shù)字和"-",在一些表單提交的地方,這是比較有用的常規(guī)判斷,這里收集有幾種不同的方法,最后還將簡要介紹下isNAN函數(shù)的使用方法和例子,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-11-11使用JavaScript實現(xiàn)檢測網(wǎng)頁是否為空閑狀態(tài)
最近開發(fā)項目時,常碰到“用戶在一定時間內(nèi)無任何操作時,跳轉(zhuǎn)到某個頁面”的需求,所以本文就來使用JavaScript實現(xiàn)這一要求,需要的可以參考下2024-03-03