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

使用CSS實現(xiàn)一個滾動陰影效果

  發(fā)布時間:2023-12-12 10:52:07   作者:超級無敵大怪獸   我要評論
為了良好的用戶體驗,需要在容器頂部可滾動的情況下增加一個陰影條,提示用戶可向上滾動,本文主要為大家詳細(xì)介紹了如何使用CSS實現(xiàn)簡單的滾動陰影效果,有需要的小伙伴可以了解下

背景

為了良好的用戶體驗,需要在容器頂部可滾動的情況下增加一個陰影條,提示用戶可向上滾動;如果容器頂部不可滾動,則不顯示陰影條,效果如下圖所示:

實現(xiàn)

首先我們定義好dom和相應(yīng)的樣式:

<!-- 容器 -->
<div class="container">
  	<!-- 陰影 -->
    <div class="shadow"></div>
  	<!-- 占位用,使容器能夠滾動 -->
    1<br/>
    2<br/>
    3<br/>
    4<br/>
    5<br/>
    6<br/>
    7<br/>
    8<br/>
    9<br/>
    10<br/>
    11<br/>
    12<br/>
    13<br/>
    14<br/>
    15<br/>
    16<br/>
</div>
// 給容器設(shè)置最大高度,使其產(chǎn)生滾動
.container {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid black;
    position: relative;
}
// 利用sticky定位實現(xiàn)吸頂效果
.shadow {
    position: sticky;
    visibility: hidden;
    top: 0;
    left: 0;
    right: 0;
    box-shadow: 0 10px 0 10px rgba(0, 0, 0, 0.2);
  	// 如果不希望陰影擋住下方內(nèi)容的點擊事件的話
    pointer-events: none;
}

核心的實現(xiàn)便是如何判斷容器頂部是否還有滾動空間,我們用到scrollTop屬性,如果scrollTop大于0,說明可以向上滾動:

import { debounce } from 'https://cdn.jsdelivr.net/npm/lodash-es@4.17.21/lodash.min.js';
// 容器
const container = document.querySelector('.container');
// 陰影
const shadow = document.querySelector('.shadow');
// 用到了lodash的防抖函數(shù),
// 通過scrollTop是否大于0來判斷容器頂部是否還有滾動空間,
// 從而控制shadow是否顯示。
const handler = debounce((e) => {
    if (e.target.scrollTop > 0) {
        shadow.style.visibility = 'visible';
    } else {
        shadow.style.visibility = 'hidden'
    }
}, 50, { leading: true });
// 監(jiān)聽滾動事件
container.addEventListener('scroll', handler);

然后就實現(xiàn)了開頭的滾動陰影效果。

舉一反三

會了頂部陰影,那怎么實現(xiàn)底部、左側(cè)、右側(cè)陰影呢?聰明的你肯定脫口而出用scrollBottom、scrollLeft、scrollRight比較一下就行了。行嗎?不太行哦,元素沒有scrollBottom、

scrollRight屬性,因此底部和右側(cè)陰影不能用這個方法實現(xiàn)。那么應(yīng)該怎么搞呢,也簡單,用到元素的scrollWidth和scrollHeight就可以實現(xiàn)scrollBottom和scrollRight的效果:

const scrollRight = scrollWidth - scrollLeft;
const scrollBottom = scrollHeight - scrollTop;
// 然后再使用前文的邏輯處理即可
......
// 但是這里還有個坑,
// 上述的scrollBottom和scrollRight是通過浮點數(shù)相減來的,
// 會有精度問題,因此比較時不是直接與0比較,而是用Number.EPSILON
// 舉個栗子
scrollRight > Number.EPSILON

其實不止?jié)L動陰影,還有一些效果也是可以用這個思路做的,比如下圖中的指示器效果:

總結(jié)

寫篇小水文,混混經(jīng)驗。我發(fā)現(xiàn)長篇的干貨數(shù)據(jù)不太好,反而是這樣幾分鐘看完的小水文數(shù)據(jù)還挺好看的。雖然水,但是也有不少知識點:

  • sticky定位實現(xiàn)吸頂效果
  • pointer-events實現(xiàn)鼠標(biāo)事件穿透
  • 判斷元素某個方向是否可滾動
  • 防抖函數(shù)以及立即執(zhí)行
  • 浮點數(shù)精度用EPSILON處理

到此這篇關(guān)于使用CSS實現(xiàn)一個滾動陰影效果的文章就介紹到這了,更多相關(guān)CSS滾動陰影內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用純 CSS 實現(xiàn)滾動陰影效果

    這篇文章主要介紹了使用純 CSS 實現(xiàn)滾動陰影效果,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-04
  • css實現(xiàn)元素四周陰影的示例代碼

    CSS的陰影效果為網(wǎng)頁設(shè)計增添了許多細(xì)節(jié)和質(zhì)感,本文就來介紹一下css實現(xiàn)元素四周陰影的示例代碼,具有一定的參考價值,感興趣的可以了解一下
    2023-12-04
  • 使用CSS實現(xiàn)Logo陰影特效

    這篇文章主要個大家介紹了如何使用CSS實現(xiàn)Logo陰影特效,文章通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,感興趣的同學(xué)可是自己動手嘗試一下
    2023-11-20
  • CSS 實現(xiàn)多彩、智能的陰影效果

    這篇文章主要介紹了CSS 實現(xiàn)多彩、智能的陰影效果,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-12
  • css文字陰影漸漸模糊效果的實現(xiàn)

    這篇文章主要介紹了css文字陰影漸漸模糊效果的實現(xiàn),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-07
  • CSS 陰影動畫優(yōu)化技巧

    這篇文章主要介紹了CSS 陰影動畫優(yōu)化技巧,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-31
  • 用CSS畫一個帶陰影的三角形的示例代碼

    這篇文章主要介紹了用CSS畫一個帶陰影的三角形的示例代碼的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨
    2019-07-31
  • css實現(xiàn)動態(tài)陰影、蝕刻文本、漸變文本效果

    這篇文章主要介紹了css實現(xiàn)動態(tài)陰影、蝕刻文本、漸變文本效果,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-11-22
  • CSS 翹邊陰影的實現(xiàn)代碼

    這篇文章主要介紹了CSS 翹邊陰影的實現(xiàn)代碼的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-15

最新評論