CSS設(shè)置自動(dòng)滾動(dòng)定位的間距的方法
介紹兩個(gè)和滾動(dòng)定位相關(guān)的 CSS 屬性:scroll-padding[1]和 scroll-margin[2]
在平時(shí)開發(fā)中,經(jīng)常會(huì)碰到需要快速定位的問題,比如常見的錨點(diǎn)定位
<ul> ??<li><a?href="#語法">語法</a></li> ??<li><a?href="#示例">示例</a></li> ??... </ul> <article> ?<h2?id="語法">語法</h2> ??<p>...</p> ??<h2?id="示例">示例</h2> ??<p>...</p> ??... </article>
這樣,在點(diǎn)擊a標(biāo)簽時(shí)會(huì)自動(dòng)定位到與之相對(duì)應(yīng)的內(nèi)容上,如下

但是,這種通過錨點(diǎn)觸發(fā)的定位默認(rèn)是緊貼滾動(dòng)容器邊緣的,如果一些定位元素,比如fixed定位的頭部,就會(huì)出現(xiàn)被遮擋的情況,如下

可以看到,“示例”這個(gè)標(biāo)題由于緊貼頂部,導(dǎo)致被sticky定位的頭部遮住了。
那么,如何讓自動(dòng)定位時(shí)讓目標(biāo)元素預(yù)留出足夠大的間距呢?
一、一行 CSS解決
沒錯(cuò),看似有些麻煩的問題其實(shí)可以通過一行 CSS 解決,那就是 scroll-margin[3] ,下面是 MDN 的介紹
scroll-margin屬性的值代表用于將盒元素拖拽到顯示區(qū)域的拖拽滾動(dòng)區(qū)域的起點(diǎn)。拖拽滾動(dòng)區(qū)域由是由轉(zhuǎn)換后邊框大小的盒元素決定的,它會(huì)找到盒元素的矩形邊界(在滾動(dòng)的容器的坐標(biāo)空間軸上),并添加指定的起點(diǎn)。
這個(gè)描述很官方,有點(diǎn)不知道在說什么??,導(dǎo)致很長(zhǎng)一段時(shí)間都不知道這個(gè)屬性的真正用途。
在上面這個(gè)例子中,可以直接給目標(biāo)設(shè)置scroll-margin
h2{
??scroll-margin:?6rem;?
}設(shè)置這個(gè)屬性后,當(dāng)自動(dòng)滾動(dòng)定位到h2時(shí),會(huì)自動(dòng)預(yù)留6rm的間隔(可以防止被頭部遮擋),下面是演示(紅框表示6rem的間隔)

是不是非常簡(jiǎn)單,最終效果如下

其實(shí),MDN官方已經(jīng)采用了這種方式,經(jīng)??纯?MDN,會(huì)發(fā)現(xiàn)有很多非常巧妙的實(shí)現(xiàn),如下

二、還有一個(gè) scroll-padding
和scroll-margin比較類似的還有一個(gè) scroll-padding[4],功能都是一樣的,只是作用對(duì)象不一樣。
在前面的例子中可以看到,scroll-margin是直接設(shè)置目前元素上的,scroll-padding不一樣,它需要設(shè)置在滾動(dòng)容器上,比如
html{
??scroll-padding:?6rem
}這種方式也是可以達(dá)到相同的效果的

一般情況下,兩種方式都可以自行選擇,如果很清楚滾動(dòng)容器是哪個(gè),可以直接選擇用scroll-padding,否則就用scroll-margin
三、其他滾動(dòng)定位方式
除了錨點(diǎn)定位以外,還有其他一些方式可以觸發(fā)滾動(dòng)定位
1. scrollIntoView
有時(shí)候,我們需要將指定元素滾動(dòng)到視線范圍之內(nèi),這時(shí)就需要用到這樣一個(gè)DOM方法:scrollIntoView[5]
element.scrollIntoView();
這個(gè)定位和前面的錨點(diǎn)定位一樣,默認(rèn)也是緊貼滾動(dòng)容器的,如果設(shè)置了scroll-margin或者scroll-pading,也可以實(shí)現(xiàn)在滾動(dòng)定位時(shí)自動(dòng)預(yù)留一定間距

2. focus 定位
在默認(rèn)情況下,元素(比如a鏈接)在focus聚焦時(shí)都會(huì)自動(dòng)滾動(dòng)到視線范圍之內(nèi)。和上面幾種情況一樣,如果有fixed定位元素,有可能在focus時(shí)被遮擋的問題。
如果設(shè)置了scroll-margin或者scroll-pading,這樣就可以避免找不到焦點(diǎn)的情況,確保一直都能看到焦點(diǎn),下面是通過tab鍵聚焦的情況

3. scroll-snap
還有一種情況是滾動(dòng)捕捉:scroll-snap-type[6],這個(gè)屬性可以讓滾動(dòng)時(shí)自動(dòng)捕捉臨界點(diǎn)。正常情況下,滾動(dòng)臨界點(diǎn)是緊貼滾動(dòng)容器的,像這樣

如果希望預(yù)留一定的距離如何處理呢?還是這個(gè)scroll-margin,下面給第二個(gè)元素設(shè)置了一定的scroll-margin,效果如下

可以看到,在滾動(dòng)到第2個(gè)元素時(shí),提前預(yù)留了一定的距離,而且還可以設(shè)置負(fù)值,這樣在滾動(dòng)到第2個(gè)元素時(shí),可以提前看到第3個(gè)的部分內(nèi)容

目前我所了解的就是這幾種定位方式,有其他的可以留言告知
四、兼容性和總結(jié)
最后來看一下兼容性,一個(gè)體驗(yàn)增強(qiáng)屬性,兼容性還不錯(cuò)

這里有個(gè)疑惑是,都出來這么久了,為啥一直不知道呢?其實(shí)我也一直被 MDN 官網(wǎng)誤導(dǎo)了,首先,scroll-margin和scroll-padding的官方示例中只有關(guān)于scroll-snap-type的應(yīng)用場(chǎng)景,導(dǎo)致我一直誤以為這個(gè)屬性就是和scroll-snap-type搭配使用的,沒有朝其他方向上思考。另外,從時(shí)間上來看,這個(gè)屬性確實(shí)是和scroll-snap-type幾乎是一同推出的(chrome上),這點(diǎn)從兼容性上可以看出,這樣有點(diǎn)更堅(jiān)信了前面的誤導(dǎo)

所以,一直以來,這樣一個(gè)超級(jí)好用的 CSS 屬性被我忽略了,可惜??
不過,現(xiàn)在了解也不晚,下面來總結(jié)一下
- 默認(rèn)情況下自動(dòng)滾動(dòng)定位都是與滾動(dòng)容器貼邊的,有時(shí)候并不美好
scroll-padding和scroll-margin可以在自動(dòng)滾動(dòng)定位時(shí)預(yù)留指定的間距scroll-margin作用對(duì)象是目標(biāo)元素,scroll-padding作用對(duì)象是滾動(dòng)容器- 滾動(dòng)定位方式有錨點(diǎn)定位、
scrollIntoView定位、focus定位、還有Scroll-snap定位 - 體驗(yàn)增強(qiáng)屬性,兼容性還不錯(cuò),主要是
safari拖后腿
以上就是CSS設(shè)置自動(dòng)滾動(dòng)定位的間距的方法的詳細(xì)內(nèi)容,更多關(guān)于CSS設(shè)置自動(dòng)滾動(dòng)間距的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
CSS深入學(xué)習(xí)之讓你認(rèn)識(shí)不一樣的margin
這篇文章主要給大家介紹了CSS中margin的用法和常見問題的分析,文中介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起看看吧。2017-06-28css解決display:inline-block;產(chǎn)生的縫隙(間隙)的方法
本篇文章主要介紹了css解決display:inline-block;產(chǎn)生的縫隙(間隙)的方法,具有一定的參考價(jià)值,有需要的可以了解一下。2016-12-14- 給當(dāng)前定高元素, 設(shè)置line-height屬性, 其屬性值等于當(dāng)前元素的height值,今天了解到了一條相關(guān)知識(shí), 明白這個(gè)方法的實(shí)現(xiàn)原理。在此與大家分享下2013-11-20
- 在網(wǎng)頁布局中經(jīng)常會(huì)用到css控制字間距和對(duì)齊方式,有些朋友對(duì)其屬性不是很熟悉,下面為大家詳細(xì)介紹下,感興趣的朋有可以參考下哈2013-06-16
如何設(shè)置單詞字體間距 css設(shè)置字體間距樣式代碼
如何設(shè)置單詞字體間距?在div布局中經(jīng)常會(huì)遇到這樣的問題,適當(dāng)?shù)拈g距可以友好界面,利用閑暇時(shí)間整理了一些,有需求的朋友可以參考下2012-12-30- HTM,CSS,怎樣去掉橫排圖片之間的間距,是我們的一大頭疼問題,于是本人搜集整理一下,曬出來和大家分享,希望可以幫助你們2012-12-11
- 我們可以從表中看到在這里可以定義文本的文字間距、字母間距、裝飾、對(duì)齊方式、縮進(jìn)方式和行高等屬性。2010-07-04
CSS教程(7):網(wǎng)頁段落行間距控制的實(shí)例
網(wǎng)頁制作Webjx文章簡(jiǎn)介:本文主要講解如何用CSS控制網(wǎng)頁段落行間距的三個(gè)實(shí)例:1、使用百分比設(shè)置行間距,2、使用像素值設(shè)置行間距,3、使用數(shù)值來設(shè)置行間距。2009-04-02CSS去除表格的默認(rèn)間距并且制作1px的細(xì)線表-CSS教程-網(wǎng)頁制作-網(wǎng)頁教學(xué)
現(xiàn)在在所謂“div css”的風(fēng)氣下,很多人放棄了表格,其實(shí)應(yīng)該讓每個(gè)標(biāo)簽物盡其用,在表現(xiàn)數(shù)據(jù)的地方,我們還是應(yīng)該使用table。但是,我們?cè)诮able的時(shí)候,會(huì)2008-10-17

