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

詳解滑動穿透(鎖body)終極探索

 更新時間:2019年04月16日 09:34:16   作者:seventhMa  
這篇文章主要介紹了滑動穿透(鎖body),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

場景

當(dāng)頁面出現(xiàn)浮層的時候,滑動浮層的內(nèi)容,正常情況下預(yù)期應(yīng)該是浮層下邊的內(nèi)容不會滾動;然而事實并非如此。

如圖所示,浮層下邊的內(nèi)容并沒有如想象中不受影響。

解決

先去github上搜索一番,發(fā)現(xiàn)有解決此問題的開源包,簡單粗暴直接挑選了其中star的最高的(body-scroll-lock)操作一番!
使用后發(fā)現(xiàn)有一些問題:

  1. 安卓端全掛
  2. ios端偶爾會有鎖不住的情況

查源碼發(fā)現(xiàn)該包在iOS端使用禁止touchmove的方式單獨(dú)處理,但是在其他端只是給body加overflow: hidden簡單處理。
于是決定寫一個針對多端通用的包來處理類似的問題。

 探索一:overflow: hidden

看到下邊的滾動肯定立刻就想到了是整個viewport的滾動,那么如果給body設(shè)置overflow: hidden,此時body的內(nèi)容就只有一屏了,肯定不會滾動了;

body { overflow: hidden; }

此方案在pc端完美解決了我們的問題,然而事情并沒有那么簡單;

再試試移動端:

移動端中并沒有出現(xiàn)期待的效果。。。

既然pc端已經(jīng)有了完美的方案,下邊我們繼續(xù)探索移動端的解決方案。

探索二:body定位

上邊想到給body設(shè)置overflow: hidden在移動端并不能解決我們的問題,是否在于body的height沒有設(shè)置

  1. 將html、body的高度都設(shè)置為100%;
  2. 給body設(shè)置絕對定位(fixed);

同時使用這兩個操作似乎完美滿足了我們的需求;


但是如圖所示,每次都會將頁面拉到最頂上的位置,這樣看起來又不完美了;

既然使用了定位,那么給一個top值不就定位到我們想要的位置了(聰明如我)。

tips: body 設(shè)置 relative 定位會頁面自身拉上去,下邊留白

多次實驗發(fā)現(xiàn)這個方案在android端中完美達(dá)到了我們想要的結(jié)果,但是在ios端并不理想;每次定位的時候會有閃動的問題;好事多磨,接著探索ios端的方案。

探索三:禁止touchmove

如果禁止掉頁面的touchmove是否可行呢?話不多說就是干!
當(dāng)彈出浮層的時候禁掉頁面元素的touchmove

document.addEventListener('touchmove', function (event) {
  event.preventDefault()
})

測試發(fā)現(xiàn)沒有達(dá)到想象中的效果,感覺這個結(jié)果并不能接受啊,禁止document 的touchmove都不能禁止?jié)L動的嗎?
進(jìn)一步的探索后發(fā)現(xiàn)原因竟是這個屬性

passive addEventListener第三個參數(shù)中傳入

原來是瀏覽器做的一些優(yōu)化,chrome passive-event-listeners
Passive Event Listeners是Chrome提出的一個新的瀏覽器特性:Web開發(fā)者通過一個新的屬性passive來告訴瀏覽器,當(dāng)前頁面內(nèi)注冊的事件監(jiān)聽器內(nèi)部是否會調(diào)用preventDefault函數(shù)來阻止事件的默認(rèn)行為,以便瀏覽器根據(jù)這個信息更好地做出決策來優(yōu)化頁面性能。當(dāng)屬性passive的值為true的時候,代表該監(jiān)聽器內(nèi)部不會調(diào)用preventDefault函數(shù)來阻止默認(rèn)滑動行為,Chrome瀏覽器稱這類型的監(jiān)聽器為被動(passive)監(jiān)聽器。
知道問題就好說了,給addEventListener傳入第三個參數(shù)

document.addEventListener('touchmove', function (event) {
  event.preventDefault()
}, { passive: false })

大功告成! 突然想到,如果浮層中還需要滾動那就不GG了! so,是不是可以有選擇性的禁止?jié)L動(在浮層中元素滾動到最頂部或者最底部之后禁止?jié)L動)。 單獨(dú)處理浮層中需要滾動的元素;

targetElement.ontouchmove = function (event) {
  const clientY = event.targetTouches[0].clientY - initialClientY

  if (targetElement && targetElement.scrollTop === 0 && clientY > 0) {
    return preventDefault(event)
  }

  if (targetElement && (targetElement.scrollHeight - 1 - targetElement.scrollTop <= targetElement.clientHeight) && clientY < 0) {
    return preventDefault(event)
  }

  event.stopPropagation()
  return true
}

這個方案在ios中完美實現(xiàn),但是在 android中還是有一點(diǎn)問題;浮層內(nèi)容拉到最頂部或者最底部的時候依然會帶動頁面的內(nèi)容有一定程度的移動。

tua-body-scroll-lock

終極方案來啦!

tua-body-scroll-lock即是在ios、android和PC各個端單獨(dú)處理,保證在每個端都可以實現(xiàn)完美的效果!

demo

安裝

$ npm i -S tua-body-scroll-lock
# OR
$ yarn add tua-body-scroll-lock

使用

移動端

import { lock, unlock } from 'tua-body-scroll-lock'

// 禁止滑動后還需要內(nèi)部可以滾動的元素(針對移動端ios處理)
const targetElement = document.querySelector("#someElementId");

lock(targetElement)
unlock(targetElement)

PC端

tips: PC端不需要targetElement, 不傳targetElement也不想要控制臺提示可以傳null

import { lock, unlock } from 'tua-body-scroll-lock'

lock()
unlock()

以上所述是小編給大家介紹的滑動穿透(鎖body)詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue中如何給data里面的變量增加屬性

    vue中如何給data里面的變量增加屬性

    這篇文章主要介紹了vue中如何給data里面的變量增加屬性,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • vue3安裝配置sass的詳細(xì)步驟

    vue3安裝配置sass的詳細(xì)步驟

    sass是css的預(yù)處理器,擴(kuò)展了css語言,提供了規(guī)則、變量、混入、選擇器、繼承、內(nèi)置函數(shù)等特性,有助于減少CSS重復(fù)的代碼,節(jié)省開發(fā)時間,下面這篇文章主要給大家介紹了關(guān)于vue3安裝配置sass的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • Vue拖動截圖功能的簡單實現(xiàn)方法

    Vue拖動截圖功能的簡單實現(xiàn)方法

    最近項目上要做一個車牌識別的功能,就需要做拖動截圖功能了,因為前段是vue,所以下面這篇文章主要給大家介紹了關(guān)于Vue拖動截圖功能的簡單實現(xiàn)方法,需要的朋友可以參考下
    2021-07-07
  • vue2.0自定義指令示例代碼詳解

    vue2.0自定義指令示例代碼詳解

    指令通常以"v-"作為前綴, 以方便Vue知道你在使用一種特殊的標(biāo)記。這篇文章主要介紹了vue2.0自定義指令的實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • Vue按回車鍵進(jìn)行搜索的實現(xiàn)方式

    Vue按回車鍵進(jìn)行搜索的實現(xiàn)方式

    這篇文章主要介紹了Vue按回車鍵進(jìn)行搜索的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • vue中的自定義指令clickOutside

    vue中的自定義指令clickOutside

    這篇文章主要介紹了vue中的自定義指令clickOutside,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue 折疊展示多行文本組件的實現(xiàn)代碼

    vue 折疊展示多行文本組件的實現(xiàn)代碼

    這篇文章主要介紹了vue 折疊展示多行文本組件,自動根據(jù)傳入的expand判斷是否需要折疊,非常完美,文章通過實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-10-10
  • vue?elementui動態(tài)添加el-input實例代碼

    vue?elementui動態(tài)添加el-input實例代碼

    最近遇到一個新的需求,需要動態(tài)添加el-input,這篇文章主要給大家介紹了關(guān)于vue?elementui動態(tài)添加el-input的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • vue時間戳和時間的相互轉(zhuǎn)換方式

    vue時間戳和時間的相互轉(zhuǎn)換方式

    本文通過示例代碼介紹了vue時間戳和時間的相互轉(zhuǎn)換方式,通過場景分析介紹了vue3使用組合式api將時間戳格式轉(zhuǎn)換成時間格式(2023年09月28日 10:00),感興趣的朋友一起看看吧
    2023-12-12
  • vue3.0關(guān)閉eslint校驗的3種方法詳解

    vue3.0關(guān)閉eslint校驗的3種方法詳解

    這篇文章主要給大家介紹了關(guān)于vue3.0關(guān)閉eslint校驗的3種方法,在實際開發(fā)過程中,eslint的作用不可估量,文中將關(guān)閉的方法介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06

最新評論