摘要:否則會出現(xiàn)兩個下拉刷新之前之后禁用炫光和回彈效果將屬性制定為,可以禁用默認(rèn)的滾動邊界效果。完整的地址源碼最終效果閱讀原文討論地址使用控制滾動行為自定義下拉刷新和溢出效果如果你想?yún)⑴c討論,請點(diǎn)擊這里
dev-reading/fe 是一個閱讀、導(dǎo)讀、速讀的 repo,不要依賴于 dev-reading/fe 學(xué)習(xí)知識。本 repo 只是一個快速了解文章內(nèi)容的工具,并不提供全文解讀和翻譯。你可以通過本平臺快速了解文章里面的內(nèi)容,找到感興趣的文章,然后去閱讀全文。
本文地址:https://github.com/dev-readin...
閱讀時間大概 3 分鐘
CSS 的新屬性 overscroll-behavior 允許開發(fā)者覆蓋默認(rèn)的瀏覽器滾動行為,一般用在滾動到頂部或者底部。
背景 滾動邊界和滾動鏈接(boundary & chaining)在 APP 中經(jīng)常使用的抽屜導(dǎo)航(drawer)中,我們期望的效果是:滾動到底部時,滾動停止,因?yàn)槲覀兊竭_(dá)了"滾動邊界"。
但是在 Web 頁面中滾動并不會停止,而是繼續(xù)滾動抽屜后面的內(nèi)容。效果如下:
我們稱這種行為叫滾動鏈接(scroll chaining)。
下拉刷新 pull-to-refresh下拉刷新是一個在移動端經(jīng)常使用的操作,Chrome 移動版也增加了下拉刷新的支持。
Twitter PWA 版本的自定義下拉刷新:
Chrome Android 版的原生下拉刷新(刷新整個頁面):
很多時候我們需要禁用原生的 pull-to-refresh 行為。
以前我們想出各種方式來處理滾動,比如:不讓頁面滾動,而是使用 touch 事件處理滾動行為,使用 100vw/vh 設(shè)置頁面高度禁止內(nèi)容溢出或滾動,等等。。。
現(xiàn)在我們可以使用 overscroll-behavior。
介紹 overscroll-behavioroverscroll-behavior 屬性有 3 個值:
auto - 默認(rèn)。元素的滾動會傳播給祖先元素。
contain - 阻止?jié)L動鏈接。滾動不會傳播給祖先,但會顯示元素內(nèi)的原生效果。例如,Android 上的炫光效果或 iOS 上的回彈效果,當(dāng)用戶觸摸滾動邊界時會通知用戶。注意:overscroll-behavior: contain 在 html 元素上使用可防止?jié)L動導(dǎo)航操作。
none - 和 contain 一樣,但它也可以防止節(jié)點(diǎn)本身的滾動效果(例如 Android 炫光或 iOS 回彈)。
阻止 fixed 定位元素的滾動傳播當(dāng)一個 fixed 定位元素滾動到邊界時,會滾動元素后面的內(nèi)容。如下:
我們可以使用 overscroll-behavior: contain 阻止這種行為。
如果我們有一個 fixed 定位的彈出層需要滾動時,默認(rèn)是這樣的,如下:
使用 overscroll-behavior: contain 可以阻止?jié)L動傳播給父元素,如下:
禁用下拉刷新 pull-to-refresh禁用原生的下拉刷新效果,只需要在 body 或 html 元素添加:
body { /* Disables pull-to-refresh but allows overscroll glow effects. */ overscroll-behavior-y: contain; }
當(dāng)我們阻止了原生的下拉刷新后,就可以實(shí)現(xiàn)自己定義的下拉刷新。否則會出現(xiàn)兩個下拉刷新:
之前:
之后:
禁用炫光和回彈效果將屬性制定為 none,可以禁用默認(rèn)的滾動邊界效果。
body { /* 禁用默認(rèn)的下拉刷新和邊界效果 但是依然可以進(jìn)行滑動導(dǎo)航 */ overscroll-behavior-y: none; }
之前:
之后:
如果想禁用左右滑動的手勢導(dǎo)航,可以使用 overscroll-behavior-x: none。
完整的 demoDemo 地址:https://ebidel.github.io/demo...
源碼:https://github.com/ebidel/dem...
最終效果:
閱讀原文:Take control of your scroll: customizing pull-to-refresh and overflow effects
討論地址:使用 CSS overscroll-behavior 控制滾動行為:自定義下拉刷新和溢出效果
如果你想?yún)⑴c討論,請點(diǎn)擊這里
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/89800.html
摘要:否則會出現(xiàn)兩個下拉刷新之前之后禁用炫光和回彈效果將屬性制定為,可以禁用默認(rèn)的滾動邊界效果。完整的地址源碼最終效果閱讀原文討論地址使用控制滾動行為自定義下拉刷新和溢出效果如果你想?yún)⑴c討論,請點(diǎn)擊這里 dev-reading/fe 是一個閱讀、導(dǎo)讀、速讀的 repo,不要依賴于 dev-reading/fe 學(xué)習(xí)知識。本 repo 只是一個快速了解文章內(nèi)容的工具,并不提供全文解讀和翻譯。你...
摘要:否則會出現(xiàn)兩個下拉刷新之前之后禁用炫光和回彈效果將屬性制定為,可以禁用默認(rèn)的滾動邊界效果。完整的地址源碼最終效果閱讀原文討論地址使用控制滾動行為自定義下拉刷新和溢出效果如果你想?yún)⑴c討論,請點(diǎn)擊這里 dev-reading/fe 是一個閱讀、導(dǎo)讀、速讀的 repo,不要依賴于 dev-reading/fe 學(xué)習(xí)知識。本 repo 只是一個快速了解文章內(nèi)容的工具,并不提供全文解讀和翻譯。你...
摘要:層疊即表示允許以多種方式來描述樣式,一個元素可以被渲染呈現(xiàn)出多種樣式。可以讓屬性的變化過程持續(xù)一段時間,而不是立即生效。比如,將元素的顏色從白色改為黑色,通常這個改變是立即生效的,使用后,將按一個曲線速率變化。 showImg(https://segmentfault.com/img/bVZwyL?w=900&h=385); CSS 的全稱是 Cascading Style Sheet...
閱讀 2864·2021-09-22 15:43
閱讀 4781·2021-09-06 15:02
閱讀 854·2019-08-29 13:55
閱讀 1687·2019-08-29 12:58
閱讀 3074·2019-08-29 12:38
閱讀 1257·2019-08-26 12:20
閱讀 2272·2019-08-26 12:12
閱讀 3321·2019-08-23 18:35