純css 實(shí)現(xiàn)tab導(dǎo)航欄下劃線跟隨動(dòng)畫(huà)

起因:
閑來(lái)無(wú)事梁棠,看到簡(jiǎn)述我的 “我的主頁(yè)” 導(dǎo)航欄上很經(jīng)典的鼠標(biāo)以上很經(jīng)典的動(dòng)畫(huà)世舰。
記得之前業(yè)務(wù)上也有要類似動(dòng)畫(huà)的時(shí)候庞瘸,但那是用的是jQuery,就直接找了個(gè)jQuery的插件许赃。
得閑剛好看到簡(jiǎn)書(shū)這動(dòng)畫(huà)止喷,便 f12 看了下代碼結(jié)構(gòu)。



最終實(shí)現(xiàn)效果:



具體實(shí)現(xiàn)代碼:

<!DOCTYPE html>
<html>
<head>
    <title></title>
    <style type="text/css">
*{
    padding: 0;
    margin: 0
}
.trigger-menu {
    border-bottom: 1px solid #f0f0f0;
    font-size: 0; /*消除li inline-block 為行內(nèi)元素后的默認(rèn)間距*/
    list-style: none;
}
.trigger-menu li {
    position: relative; /*關(guān)鍵點(diǎn): 為每個(gè)li設(shè)置絕對(duì)定位*/
    display: inline-block; /*使li為塊級(jí)元素混聊,可以橫向排列*/
    padding: 8px 0;
    border-bottom: 2px solid transparent
}
.trigger-menu li:after { /*hover狀態(tài)下時(shí)的底部橫線*/
    content: "";
    position: absolute; /*關(guān)鍵點(diǎn): 該元素行對(duì)定位于 li*/
    left: 50%;
    bottom: -2px;
    width: 100%;
    opacity: 0;
    border-bottom: 2px solid #646464;
    transform: translate(-50%) scaleX(0);
    transition: .2s ease-in-out;
}
.trigger-menu li:hover::after {
    opacity: 1;
    transform: translate(-50%) scaleX(1);
}
.trigger-menu a {
    padding: 13px 20px;
    font-size: 15px;
    font-weight: 700;
    color: #969696;
    line-height: 25px;
    text-decoration: none;
}
.trigger-menu a:hover {
    color: #646464
}

/*點(diǎn)擊后添加 .active 樣式*/
.trigger-menu li.active{
    color: #646464;
    border-bottom: 2px solid #646464  
}
.trigger-menu li.active a{
    color: #646464;
}

    </style>

</head>
<body>
<ul class="trigger-menu">
    <li><a href="">文章</a></li>
    <li><a href="">動(dòng)態(tài)</a></li>
    <li><a href="">最新評(píng)論</a></li>
    <li class="active"><a href="">熱門(mén)</a></li>
</ul>
</body>
</html>



解析:

  1. 關(guān)鍵點(diǎn)
    利用元素的after偽類創(chuàng)建底部橫線启盛。

  2. 橫線怎么剛好定在元素的底部呢?
    利用元素間的相對(duì)定位來(lái)使橫線定位到li底部。 li 設(shè)置為絕對(duì)定位 relative僵闯,然后把 after 設(shè)置 absolute 相對(duì)于li來(lái)定位卧抗。
    bottom: -2px?要使橫線剛好在ul底部邊框上鳖粟,因?yàn)闄M線高度為2px社裆,所以橫線定在底部然后上移兩個(gè)像素。
    而 left: 50%;transform: translate(-50%); 是讓元素位于父級(jí)居中向图。

3.動(dòng)畫(huà)是怎么實(shí)現(xiàn)的泳秀?
如果一開(kāi)始就讓橫線展示出來(lái)要怎么寫(xiě)?

.trigger-menu li:after {
    content: "";
    position: absolute; 
    left: 50%;
    bottom: -2px;
    width: 100%;
    border-bottom: 2px solid #646464;
    transform: translate(-50%) scaleX(1);  /*原本為scaleX(0)*/
}

這樣一開(kāi)始橫線就是出現(xiàn)的榄攀。而實(shí)例中我們hover時(shí)讓橫線出現(xiàn)的做法是 設(shè)置透明度可見(jiàn)和不縮放嗜傅,如下

.trigger-menu li:hover::after {
    transform: translate(-50%) scaleX(1);
}

即一開(kāi)始橫線隱藏了,是因?yàn)?scaleX(0)檩赢, 把a(bǔ)fter縮寫(xiě)到0吕嘀,即視覺(jué)上看不見(jiàn)(實(shí)際上還是占這那塊位置)。而hover時(shí)贞瞒,把 scaleX(1)設(shè)為不縮放偶房,即能看到完整的橫線。

那么是怎么做到橫線由中間向兩邊延展军浆?就是讓橫線位于父級(jí)居中 “l(fā)eft: 50%; transform: translate(-50%)”

這樣就完成了我們所看到的動(dòng)效了棕洋。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市乒融,隨后出現(xiàn)的幾起案子掰盘,更是在濱河造成了極大的恐慌,老刑警劉巖赞季,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件愧捕,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡碟摆,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)叨橱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)典蜕,“玉大人,你說(shuō)我怎么就攤上這事罗洗∮涮颍” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵伙菜,是天一觀的道長(zhǎng)轩缤。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么火的? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任壶愤,我火速辦了婚禮,結(jié)果婚禮上馏鹤,老公的妹妹穿的比我還像新娘征椒。我一直安慰自己,他們只是感情好湃累,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布勃救。 她就那樣靜靜地躺著,像睡著了一般治力。 火紅的嫁衣襯著肌膚如雪蒙秒。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,829評(píng)論 1 290
  • 那天宵统,我揣著相機(jī)與錄音晕讲,去河邊找鬼。 笑死榜田,一個(gè)胖子當(dāng)著我的面吹牛益兄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播箭券,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼净捅,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了辩块?” 一聲冷哼從身側(cè)響起蛔六,我...
    開(kāi)封第一講書(shū)人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎废亭,沒(méi)想到半個(gè)月后国章,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡豆村,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年液兽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掌动。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡四啰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粗恢,到底是詐尸還是另有隱情柑晒,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布眷射,位于F島的核電站匙赞,受9級(jí)特大地震影響佛掖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜涌庭,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一芥被、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧脾猛,春花似錦撕彤、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至愉昆,卻和暖如春职员,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背跛溉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工焊切, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人芳室。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓专肪,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親堪侯。 傳聞我的和親對(duì)象是個(gè)殘疾皇子嚎尤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容

  • 一、CSS入門(mén) 1伍宦、css選擇器 選擇器的作用是“用于確定(選定)要進(jìn)行樣式設(shè)定的標(biāo)簽(元素)”芽死。 有若干種形式的...
    寵辱不驚丶?xì)q月靜好閱讀 1,589評(píng)論 0 6
  • 1、垂直對(duì)齊 如果你用CSS次洼,則你會(huì)有困惑:我該怎么垂直對(duì)齊容器中的元素关贵?現(xiàn)在,利用CSS3的Transform卖毁,...
    kiddings閱讀 3,153評(píng)論 0 11
  • (這是15年初學(xué)css時(shí)記的筆記) 選擇器 簡(jiǎn)單選擇器 標(biāo)簽選擇器 直接把標(biāo)簽名加前面揖曾。 類選擇器 用.+ cla...
    burningalive閱讀 938評(píng)論 0 0
  • 1、屬性選擇器:id選擇器 # 通過(guò)id 來(lái)選擇類名選擇器 . 通過(guò)類名來(lái)選擇屬性選擇器 ...
    Yuann閱讀 1,621評(píng)論 0 7
  • CSS參考手冊(cè) 一亥啦、初識(shí)CSS3 1.1 CSS是什么 CSS3在CSS2.1的基礎(chǔ)上增加了很多強(qiáng)大的新功能炭剪。目前...
    沒(méi)汁帥閱讀 3,561評(píng)論 1 13