阻止移動(dòng)端touchmove與scroll事件沖突技巧
正文
在移動(dòng)端開發(fā)過程中,如果要實(shí)現(xiàn)一個(gè)元素或按鈕的拖動(dòng)定位,會(huì)出現(xiàn)很多坑。例如:元素上下移動(dòng)過程中,會(huì)觸發(fā) body 的 scroll 事件,導(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 改善滾屏性能以了解更多。 |
signal | AbortSignal,該 AbortSignal 的 abort() 方法被調(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)文章
H5實(shí)現(xiàn)仿flash效果的實(shí)現(xiàn)代碼
這篇文章主要介紹了H5實(shí)現(xiàn)仿flash效果的實(shí)現(xiàn)代碼的相關(guān)資料,希望通過本文能幫助到大家,實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09基于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é)
在我們?nèi)粘9ぷ鞯臅r(shí)候,利用javaScript判斷一個(gè)字符串中是否包括有數(shù)字和"-",在一些表單提交的地方,這是比較有用的常規(guī)判斷,這里收集有幾種不同的方法,最后還將簡(jiǎn)要介紹下isNAN函數(shù)的使用方法和例子,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-11-11使用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í)固定的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04JavaScript函數(shù)綁定用法實(shí)例分析
這篇文章主要介紹了JavaScript函數(shù)綁定用法,結(jié)合實(shí)例形式分析了javascript函數(shù)綁定的原理、實(shí)現(xiàn)方法與相關(guān)操作技巧,需要的朋友可以參考下2017-11-11