Css和JS實現(xiàn)下劃線動效的方法示例
發(fā)布時間:2020-02-03 15:37:48 作者:潘雄
我要評論

這篇文章主要介紹了Css和JS實現(xiàn)下劃線動效的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
本文主要講述兩種下劃線動效效果,第一種懸停時 X軸由內(nèi)向外展開實現(xiàn)動畫效果,第二種為左右自動展示,由左向右,或由右向左??!
實現(xiàn)的主要效果是利用偽類標(biāo)簽,以及hover,利用transfromm trition實現(xiàn)動畫效果
x軸由內(nèi)向外展開
利用貝塞爾曲線利用橫線的動畫實現(xiàn),具體代碼如下:
ul { display: flex; padding: 0; margin: 0; list-style-type: none; } ul:hover li:not(:hover) a { opacity: 0.2; } ul li { position: relative; padding: 30px 25px 30px 25px; cursor: pointer; } ul li::after { position: absolute; content: ""; top: 100%; left: 0; width: 100%; height: 2px; background: #3498db; transform: scaleX(0); transition: 0.4s cubic-bezier(0.165, 0.84, 0.44, 1); } ul li:hover::after, ul li.active::after { transform: scaleX(1); }
左右橫移下劃線動畫特效
主要利用js判斷鼠標(biāo)移開時的位置,對動畫效果的進行左右移入移出顯示
js代碼如下:
document.querySelectorAll('a').forEach(elem => { elem.onmouseenter = elem.onmouseleave = e => { const tolerance = 5; const left = 0; const right = elem.clientWidth; let x = e.pageX - elem.offsetLeft; if (x - tolerance < left) x = left; if (x + tolerance > right) x = right; elem.style.setProperty('--x', `${x}px`); }; });
css 利用偽類標(biāo)簽進行動畫效果的動畫實現(xiàn)
css代碼如下:
a { position: relative; font-weight: 600; text-decoration: none; color: rgba(0, 0, 0, 0.4); transition: color .3s ease; } a::after { --scale: 0; content: ''; position: absolute; left: 0; right: 0; top: 100%; height: 3px; background: #4c81c9; -webkit-transform: scaleX(var(--scale)); transform: scaleX(var(--scale)); -webkit-transform-origin: var(--x) 50%; transform-origin: var(--x) 50%; transition: -webkit-transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1); transition: transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1); transition: transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.535, 0.05, 0.355, 1); } a:hover { color: #4c81c9; } a:hover::after { --scale: 1; }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
- 這篇文章主要介紹了純CSS實現(xiàn)導(dǎo)航欄下劃線跟隨效果,本文圖文并茂實例代碼詳解,給大家介紹的非常詳細(xì),需要的朋友參考下吧2019-12-09
純CSS實現(xiàn)導(dǎo)航欄下劃線跟隨的示例代碼
這篇文章主要介紹了純CSS實現(xiàn)導(dǎo)航欄下劃線跟隨的示例代碼的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-11- 這篇文章主要介紹了純CSS實現(xiàn)導(dǎo)航欄下劃線跟隨滑動效果,需要的朋友可以參考下2018-03-29
- 這篇文章主要介紹了CSS中的下劃線text-decoration屬性使用進階,文章前面則使用摘自w3cschool的基本使用知識進行小回顧,需要的朋友可以參考下2015-08-12
- 用過CSS hack的朋友應(yīng)該知道,用下劃線命名也是一種hack,如使用_style這樣的命名,可以讓IE外的大部分瀏覽器忽略這個樣式的定義。這篇文章主要為大家介紹了css布局命名時2014-06-16
- 下面為大家展示一個實例:未被點擊時超鏈接文字無下劃線,顯示為藍(lán)色;當(dāng)鼠標(biāo)在鏈接上時有下劃線,鏈接文字顯示為紅色;當(dāng)點擊鏈接后,鏈接無下劃線,顯示為綠色,感興趣的2013-06-21
- 本文主要介紹了純CSS實現(xiàn)了下劃線的交互動畫效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)2023-03-06