精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

純 CSS 實現標簽自動顯示超出數量

開發 前端
1. 計數累加器可以放在滾動驅動動畫中,這樣在動畫觸發時也就相當于計數器生效了,這樣就能統計可視區的標簽數量了。

現代CSS強大的令人難以置信。

這次我們來用 CSS 實現這樣一個功能:有多個寬度不同的標簽水平排列,當外層寬度不足時,會提示超出的數量,演示效果如下:

圖片圖片

如果讓我用 JavaScript來實現估計都有點折騰,畢竟寬度都是動態的,要監聽各部分的尺寸變化,包括標簽的位置和外層的寬度,總之不是一兩行代碼就能搞定的。

現如今,純CSS也能完美的實現這樣的效果,而且比 JS 實現更加簡單,一起來看看吧!

一、CSS 實現思路

很多時候,CSS并沒有直接的實現方式,需要“繞”點彎路,將需求拆分成很多小點,然后逐一突破。

回到本文這里,其實有幾個問題需要考慮:

  1. CSS 如何動態累計數字?
  2. CSS 如何知道哪些元素在容器之外?
  3. CSS 如何區分是否溢出(顯示數量)

關于第3點,其實在之前這篇文章中有詳細介紹,有興趣可以回顧一下,非常有意思。

純 CSS 檢測文本是否溢出

那么第一點,CSS有沒有什么方式可以統計數量呢?

沒錯,相信很多小伙伴已經猜到了,就是利用 CSS計數器,示意如下:

counter-reset: num var(--num);
counter-increment: num;
::after{
	content: "+"counter(num);
}

關于計數器,我之前也在很多文章中有用到。

你可能不需要 JS!CSS實現一個計時器

如何讓CSS計數器支持小數的動態變化?

還在使用定時器嗎?CSS 也能實現電子時鐘

動畫合成小技巧!CSS 實現動感的倒計時效果

自定義計數器小技巧!CSS 實現長按點贊累積動畫

然后是第二點,CSS有什么方式可以知道元素是出去了還是在視野之內呢?

如果是用 JS來判斷的話,最穩妥的方式應該Intersection Observer(交叉觀察者),相信很多同學都用過,這個在圖片懶加載非常有用。

交叉觀察器 API - Web API 接口參考 | MDN (mozilla.org)[1]。

那么,CSS中有什么類似的呢?沒錯,還是之前提到過的CSS滾動驅動動畫。

不過這里用到的是視圖進度,也就是關注的是元素自身位置,元素進入到容器范圍之內就會觸發動畫,非常類似 JS中的Intersection Observer。

tag{
  animation: appear;
  animation-timeline: view(inline);
  animation-range: contain;
}
@keyframes appear{
  to {
    background-color: #9747FF;
  }
}

好了,關鍵原理就這些了,我們需要做的就是想辦法將「計數器」和「元素進出容器范圍」關聯起來就行了,接著往下看。

二、CSS 計數器

利用 CSS 計數器,我們可以很輕松的統計元素的數量。

先簡單布局一下文章開頭的例子,HTML如下所示:

<div class="con">
  <a class="tag">HTML</a>
  <a class="tag">CSS</a>
  <a class="tag">JavaScript</a>
  <a class="tag">Flutter</a>
  <a class="tag">Vue</a>
  <a class="tag">React</a>
  <a class="tag">Svelte</a>
</div>
<span class="num"></span><!--用來計數的標簽-->

然后美化一下:

.con{
  display: flex;
  gap: 5px;
  padding: 5px;
  overflow: hidden;
}
.tag{
  padding: .2em .5em;
  background-color: #c49ef5;
  color: #fff;
  border-radius: 4px;
  animation: appear;
}
.num::after{
  content: "+0";
  padding: .2em .5em;
  background-color: #FFE8A3;
  color: #191919;
  border-radius: 4px;
}

這樣就得到了水平排列的 tag 布局(超出隱藏),后面跟一個數字。

圖片圖片

現在我們定義一個計數器,然后通過每個tag進行累計,有多個tag相當于多少次累加,最后在::after中顯示出來。

.con{
  counter-reset: num;  /*計數器初始值,默認為0*/
}
.tag{
  counter-increment: num; /*計數器增量值,默認為1*/
}
.num::after{
  content: "+"counter(num); 
}

默認計數器的起始值是 0,每次累計是1,所以這里最后得到了7,這樣就能實時統計元素的數量了。

圖片圖片

當然,我們也可以自定義這些默認值,比如:

.con{
  counter-reset: num 10;
}
.tag{
  counter-increment: num -1;
}

這種情況下,起始值是10,增量值是-1,所以最后得到了3,如下:

圖片圖片

那么,該如何統計容器之外的標簽數量呢?

三、CSS 滾動驅動動畫

這里我們要利用CSS 視圖進度時間軸,也就是觀察元素自身的位置,在進入到容器范圍之內執行動畫。

拿上面這個例子,我們給標簽添加一個動畫,讓標簽在進入到容器之內時變個顏色,實現如下:

.tag{
  animation: appear;
  animation-timeline: view(inline);
}
@keyframes appear{
  to {
    background-color: #4d47ff;
  }
}

由于是水平方向,所以這里需要設置view(inline) ,效果如下:

圖片圖片

好像不是很明顯?這是因為動畫是在整個視區內過渡的,我們可以改變動畫時間線的區間animation-range,讓這個動畫在進出的一瞬間就變化。

.tag{
  animation: appear;
  animation-timeline: view(inline);
  animation-range: contain;
}
@keyframes appear{
  from,to {
    background-color: #4d47ff;
  }
}

效果如下:

圖片圖片

那么,這個效果和前面的計數器有什么關聯呢?

從效果上來看,在視區內會執行一個動畫,如果在這個動畫中加入計數器的累加會怎么樣呢?先去除原先的累加器。

.tag{
  /* counter-increment: num; */
}
@keyframes appear{
  from,to {
    background-color: #4d47ff;
    counter-increment: num;
  }
}

效果如下:

圖片圖片

可以看到計數器已經生效了,不過現在統計的在「可視區內」標簽的數量。而我們要統計的是「可視區外」的數量,好像反過來了,如何實現呢?

這里有兩種思路。

第一種,用總數減去可視區內的數量,不就行了嗎?由于現在動畫是針對可視區內的,我們可以給計數器設置一個初始值,就是總量,然后動畫中給累加值設置為-1,就相當于減去當前數量了,實現如下:

.con{
	counter-reset: num 7;
}
@keyframes appear{
  from,to {
    background-color: #4d47ff;
    counter-increment: num -1;
  }
}

這樣就完美統計出了可視區外的數量了。

圖片圖片

還有一種方式,我覺得更加巧妙,需要反向思考。原理是重置當前的累加值,比如默認情況下,正常累加,進入可視范圍,把累加值設置為0,不就相當于可視區外的正常累加了嗎?

.tag{
  counter-increment: num;
}
@keyframes appear{
  from,to {
    background-color: #4d47ff;
    counter-increment: num 0;
  }
}

同樣能達到相同的效果

圖片圖片

現在基本已經達到我們需要的效果了。

四、其他細節修正

首先是,在超出范圍時,需要在邊緣出添加一個半透明蒙層,這樣體驗效果會更好。

半透明蒙層很好實現,只需要添加一個水平漸變的mask遮罩就行了。

.con{
  -webkit-mask: linear-gradient(to right, #fff calc(100% - 30px), transparent);
}

效果如下:

那么,如何在沒有超出時,不出現這個遮罩呢?

利用CSS滾動驅動動畫,可以檢測容器是否可滾動,也就是是否超出。所以我們只需要將遮罩放在滾動驅動動畫里就行了,關鍵實現如下

.con{
  animation: check;
  animation-timeline: scroll(x self);
}
@keyframes check{
  from,to {
    -webkit-mask: linear-gradient(to right, #fff calc(100% - 30px), transparent);
  }
}

效果如下:

還有一個問題,希望在沒有超出的時候不顯示后面的數量。

關于這個,我本來是打算用樣式查詢來實現,但是遇到了一個問題,由于樣式查詢只能匹配到子元素,所以不得不將顯示數量的標簽放到.con容器內。但是這樣一來,mask遮罩就會出現問題,就像這樣:

遮罩層連同數量標簽一起被裁剪了!

于是又想出了另一種方案,這個在以前的布局中其實用到的更多,那就是負margin。

實現很簡單,給標簽容器一個的負margin-right,這樣,右邊的數量就會被左邊的標簽蓋住,比如

.con{
  margin-right: -20px;
}

效果如下:

是不是已經被蓋住一部分了?我們繼續向左偏移。

.con{
  margin-right: -50px;
}

這樣就完全看不到右邊的數量了。

那么,如何在超出時顯示數量呢?這里就體現出負margin的好處了,可以借助前一個元素來隱藏后一個元素,在這里,我們直接在前面的動畫中還原margin就行了。

.con{
  animation: check;
  animation-timeline: scroll(x self);
}
@keyframes check{
  from,to {
    -webkit-mask: linear-gradient(to right, #fff calc(100% - 30px), transparent);
    margin-right: 0;
  }
}

這樣就完美實現了文章開頭所示效果了。

你也可以訪問以下鏈接來體驗真實效果(Chrome115+)

  • CSS auto tag num (juejin.cn)[2]
  • CSS auto tag num (codepen.io)[3]

五、總結一下

以上就是本文的全部內容了,不知道你學會了嗎?下面總結一下實現重點:

  1. 很多時候,CSS并沒有直接的實現方式,需要“繞”點彎路
  2. CSS計數器可以實現數字累加
  3. CSS滾動驅動動畫可以檢測元素是否在可視范圍之內
  4. CSS滾動驅動動畫還能檢測元素是否內容超出
  5. 計數累加器可以放在滾動驅動動畫中,這樣在動畫觸發時也就相當于計數器生效了,這樣就能統計可視區的標簽數量了
  6. 樣式查詢只能匹配到子元素,但是用子元素會受到mask遮罩的影響
  7. 負margin可以借助前一個元素來隱藏后一個元素
責任編輯:武曉燕 來源: 前端偵探
相關推薦

2024-08-29 08:13:58

2021-10-19 22:23:47

CSSBeautiful按鈕

2022-02-21 07:02:16

CSSbeautiful按鈕

2022-08-10 16:08:38

鴻蒙CSS

2013-04-08 14:07:28

CSS

2020-11-04 13:55:06

CSS密室逃脫前端

2021-01-19 12:16:10

CSS前端UI

2022-08-29 17:39:53

應用開發css動畫

2017-04-27 14:05:59

CSS動畫前端

2023-08-03 09:12:02

2015-04-24 10:05:15

HTML+CSS阿童木頭像

2021-01-25 06:37:06

Css前端CSS 特效

2022-08-04 06:57:54

CSS拼圖游戲

2023-04-17 09:08:27

CSS計時器

2024-07-31 20:38:18

2010-09-06 15:46:08

CSSDIV

2022-03-28 08:44:15

css3水波動畫

2021-02-09 07:26:38

前端css技術熱點

2021-08-23 06:25:57

CSS 技巧animation

2023-07-03 08:51:41

選擇器detailssummary
點贊
收藏

51CTO技術棧公眾號

欧美激情精品久久| 公共露出暴露狂另类av| 五月婷婷激情视频| 久久在线视频| 精品福利在线导航| 欧洲av无码放荡人妇网站| 日本在线免费看| 成人免费视频app| 国产精品视频免费在线| 久久99久久久| 久久精品国产亚洲夜色av网站 | 亚洲免费在线视频| 欧美精品一区二区三区在线看午夜 | 91成人观看| 亚洲免费福利视频| 人妻精品久久久久中文字幕69| 久久uomeier| 一区二区三区不卡视频| 视频在线一区二区三区| 日本韩国免费观看| 国产一区啦啦啦在线观看| 日本道色综合久久影院| 国产在线视频99| 亚洲精品小说| 在线看日韩欧美| 偷偷色噜狠狠狠狠的777米奇| 国产精品色婷婷在线观看| 在线视频亚洲一区| av天堂永久资源网| 丰满的护士2在线观看高清| 国产精品久久久久精k8| 欧美一区二区三区在线播放| 免费观看黄色av| 国产精品夜夜爽| 在线观看视频91| 国产乱淫av片杨贵妃| 国产淫片在线观看| 国产精品超碰97尤物18| 亚洲无玛一区| 中文字幕日产av| 亚洲精品孕妇| 欧美激情视频网址| 欧美日韩亚洲国产另类| 欧美色图五月天| 亚洲高清一区二| 日本少妇一区二区三区| 天堂久久av| 欧美一区二区在线视频| 羞羞的视频在线| 三级性生活视频| 色网站免费观看| 国产精品亚洲综合一区在线观看| 国产精品网址在线| 国产一区二区在线不卡| 99伊人成综合| 欧美亚洲视频一区二区| 国产一区二区三区影院| 国产精品久久久亚洲一区| 国产91对白在线播放| av黄色在线看| 日韩高清电影一区| 国产日产欧美精品| 国产精品久久久久久无人区| 韩国成人福利片在线播放| 91手机视频在线观看| www.麻豆av| 成人美女视频在线观看| 精品一区久久| 成人午夜影视| 国产精品短视频| 亚洲色婷婷久久精品av蜜桃| 久草在线新免费首页资源站| 精品国产91久久久久久| 成人一区二区三| 欧美综合影院| 精品久久一区二区三区| 中文字幕 亚洲一区| 教室别恋欧美无删减版| 久久久精品影院| 日韩欧美亚洲一区二区三区| 丝袜脚交一区二区| 51精品国产人成在线观看| 亚洲精品综合久久| 久久网站最新地址| 日本久久高清视频| 国产调教在线| 制服丝袜一区二区三区| 污污污www精品国产网站| 精品国产一级毛片| 欧美久久精品午夜青青大伊人| 亚洲国产综合久久| 免费看欧美女人艹b| 动漫精品视频| av国产在线观看| 亚洲一本大道在线| 亚洲黄色a v| 黄色在线播放网站| 久久先锋资源网| 天堂av在线中文| 韩日成人影院| 欧美v日韩v国产v| 久久婷婷五月综合| 污的网站在线观看| 亚洲成人精品一区二区| 免费在线激情视频| 欧美a级大片在线| 亚洲人永久免费| 男女羞羞免费视频| 三级久久三级久久久| 亚洲最大成人在线| 成人午夜电影在线观看| 精品久久久久久久久中文字幕| 亚洲美女爱爱视频| 奇米狠狠一区二区三区| 久久精品视频导航| 日本在线视频中文字幕| 国产高清在线精品| 一区二区三区电影| 免费在线观看黄| 在线亚洲精品福利网址导航| 青青草视频网站| 九一国产在线观看| 欧美wwwww| 国产成人精品久久二区二区91| 国产免费av电影| 中文字幕av免费专区久久| 欧美丰满熟妇bbbbbb百度| 亚洲高清在线一区| 久久综合伊人77777尤物| 波多野结衣理论片| 久久久精品综合| 免费高清在线观看免费| 欧美国产极品| 97精品伊人久久久大香线蕉| 亚洲精品97久久中文字幕| 亚洲天堂福利av| 999久久久精品视频| 日韩欧美一区二区三区在线视频| 国产成人久久久精品一区| 日本亚洲一区| 欧美日韩在线视频观看| 人人妻人人澡人人爽人人精品| 在线欧美日韩| 狠狠色综合网站久久久久久久| heyzo在线| 亚洲精品xxxx| 精品免费囯产一区二区三区| www久久精品| www黄色av| 欧洲福利电影| 国产欧美一区二区| 青青青青在线| 欧美一区日本一区韩国一区| 欧美成人精品激情在线视频| 成人精品小蝌蚪| 国产伦精品一区二区三区四区视频_| 国产精品丝袜在线播放| 97视频在线观看成人| 久蕉依人在线视频| 欧美亚洲愉拍一区二区| 操她视频在线观看| 国产做a爰片久久毛片| 欧美黑人在线观看| 欧美日韩一本| 国产精品美乳在线观看| 日韩免费啪啪| 精品美女一区二区三区| 国产精品区在线| 国产不卡av一区二区| 国产精品日韩精品| gogo在线观看| 亚洲制服丝袜av| 午夜啪啪小视频| 欧美色综合网| 欧美日韩在线观看一区二区三区| 国产成人精品亚洲日本在线观看| 国产一区二区三区18| 91免费视频播放| 一区二区三区日韩| 人妻激情偷乱视频一区二区三区| 伊人久久亚洲美女图片| 免费在线观看91| 国产区视频在线| 91精品一区二区三区久久久久久| 国产乱码久久久久久| 欧美韩国一区二区| 亚洲女则毛耸耸bbw| 欧美日韩亚洲三区| 激情小说网站亚洲综合网| 神马电影网我不卡| 欧美精品亚州精品| 国产一级片在线播放| 制服视频三区第一页精品| www亚洲视频| 亚洲三级电影全部在线观看高清| 久久人人爽人人人人片| 亚洲男人影院| 国产精品8888| 狠狠做六月爱婷婷综合aⅴ| 成人av免费看| 人人精品久久| 日本久久精品视频| 污片在线免费观看| 久久黄色av网站| 九色网友自拍视频手机在线| 日韩免费看网站| 中文字幕在线网站| 欧美性猛交xxxx免费看| 黄色一级视频免费观看| 国产精品毛片大码女人| 瑟瑟视频在线观看| 不卡的电视剧免费网站有什么| 欧美男女交配视频| 久久综合图片| 免费黄色日本网站| 尤物在线精品| 久久久国内精品| 亚洲第一偷拍| 亚洲精品一区二区毛豆| 久久99精品久久久久久园产越南| 国产精品久久波多野结衣| 成年永久一区二区三区免费视频| 国产精品69久久久久| 中文字幕在线中文字幕在线中三区| 九色精品免费永久在线| 成人免费观看视频大全| 中文字幕日韩精品在线| 你懂得在线网址| 精品亚洲aⅴ在线观看| 天堂中文资源在线观看| 欧美成人猛片aaaaaaa| 国产欧美综合视频| 宅男在线国产精品| 国产精品视频一区二区三区,| 欧美色精品在线视频| 中文字幕精品视频在线观看| 欧美午夜电影在线| 天天综合网入口| 欧美日韩国产一区在线| 亚洲精品www久久久久久| 五月综合激情日本mⅴ| 国产一级免费观看| 亚洲成人在线免费| jizz国产免费| 午夜精品一区在线观看| 91精品国产乱码久久久张津瑜| 亚洲妇熟xx妇色黄| 一区二区三区视频免费看| 欧美日韩国产黄| xx欧美撒尿嘘撒尿xx| 精华区一区二区三区| 亚洲欧美日韩一区二区| 免费观看av网站| 久久九九国产精品| 国产探花视频在线播放| 国产精品剧情在线亚洲| 永久免费看片直接| 亚洲一区影音先锋| 国产午夜精品一区二区理论影院| 亚洲精品乱码久久久久久久久| 草视频在线观看| 精品国产户外野外| 一级黄色在线视频| 欧美日韩视频专区在线播放| 国产精品久久久久久久久毛片 | 亚洲人成精品久久久| 久久精品99久久香蕉国产色戒| 国产黄色片网站| 亚洲国产精品国自产拍av秋霞| 懂色av成人一区二区三区| 日韩精品免费一线在线观看| 第一页在线观看| 欧美理论电影在线观看| 国产在线美女| 久久久亚洲国产天美传媒修理工| 手机在线观看av| 国产美女久久精品| 都市激情亚洲| 午夜老司机精品| 欧美日韩国产高清| 97公开免费视频| 国产福利电影一区二区三区| 色噜噜日韩精品欧美一区二区| 国产精品久久久久9999吃药| 国产乡下妇女做爰视频| 欧美性色黄大片| 亚洲精选一区二区三区| 一级做a爰片久久毛片美女图片| 国产在线看片| 国产成人av在线| 91精品啪在线观看国产手机 | 超碰免费在线观看| 欧美日本高清一区| 秋霞国产精品| 国产综合18久久久久久| 99久久www免费| 国产淫片免费看| 国产一区二区视频在线播放| 熟女少妇一区二区三区| 一区二区三区国产精品| 中文字幕欧美人妻精品一区蜜臀| 亚洲国产毛片完整版| 免费观看久久久久| 国产成人精品av在线| 丁香一区二区| 这里只有精品66| 亚洲综合不卡| 亚洲麻豆一区二区三区| 国产精品久久久久久一区二区三区| 圆产精品久久久久久久久久久| 7777精品伊人久久久大香线蕉经典版下载 | 丝袜情趣国产精品| 男人皇宫亚洲男人2020| 99re在线| 亚洲综合激情在线| 国产喷水theporn| 久久夜色精品国产噜噜av| 国产小视频在线观看免费| 91麻豆精品国产91久久久使用方法 | 国产精品1区二区.| 国产美女网站视频| 日本丶国产丶欧美色综合| 婷婷国产在线| 欧美巨猛xxxx猛交黑人97人| 亚洲二区av| 亚洲一区二区三区涩| 日韩精品免费视频人成| 扒开jk护士狂揉免费| 好吊成人免视频| 色天堂在线视频| 97av视频在线| 日韩欧美ww| 国模无码视频一区二区三区| www.亚洲精品| 国产精品a成v人在线播放| 精品免费日韩av| 国产福利电影在线播放| 好吊色欧美一区二区三区视频| 在线日韩av| 一区二区免费在线观看视频| 亚洲成人第一页| 天堂在线免费av| 欧美专区在线播放| 国产欧美日韩免费观看 | 国产成人在线视频网站| 一区二区三区影视| 日韩区在线观看| 国内老司机av在线| 精品一区日韩成人| 亚洲欧美卡通另类91av| 在线观看国产精品一区| 欧洲一区二区av| 在线视频自拍| 91人成网站www| 欧美日韩爆操| 欧美亚一区二区三区| 91久久国产最好的精华液| 婷婷五月在线视频| 91黄色精品| 一本一道久久综合狠狠老精东影业| 91视频啊啊啊| 欧美中文字幕一区二区三区 | 四季av日韩精品一区| 欧美亚洲在线视频| 成人6969www免费视频| 中文字幕国产高清| 亚洲成av人在线观看| 伦理片一区二区三区| 成人国产亚洲精品a区天堂华泰| 午夜久久影院| 9.1成人看片免费版| 欧美电影一区二区三区| 91九色在线播放| 日韩videos| 国产69精品久久777的优势| 在线观看黄网站| 日韩亚洲欧美中文高清在线| 日韩欧美久久| 成年人视频在线免费| 综合久久一区二区三区| 国产91久久久| 国产精品久久久久久久久久尿| 亚洲国产精品91| wwwwxxxx国产| 日韩亚洲电影在线| 香蕉视频亚洲一级| 免费cad大片在线观看| 久久婷婷成人综合色| 精品久久久免费视频| 国产91色在线免费| 欧美特黄a级高清免费大片a级| 实拍女处破www免费看| 欧美一二三区在线| 日本成人福利| 国精产品一区一区三区视频| 国产精品久久久久久久午夜片| 五月婷婷狠狠干| 亚洲一区二区三区四区在线播放 | 国产午夜精品一区理论片| 97人人做人人人难人人做|