Css和JS實(shí)現(xiàn)下劃線動效的方法示例
發(fā)布時(shí)間:2020-02-03 15:37:48 作者:潘雄
我要評論
這篇文章主要介紹了Css和JS實(shí)現(xiàn)下劃線動效的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
本文主要講述兩種下劃線動效效果,第一種懸停時(shí) X軸由內(nèi)向外展開實(shí)現(xiàn)動畫效果,第二種為左右自動展示,由左向右,或由右向左??!
實(shí)現(xiàn)的主要效果是利用偽類標(biāo)簽,以及hover,利用transfromm trition實(shí)現(xiàn)動畫效果
x軸由內(nèi)向外展開

利用貝塞爾曲線利用橫線的動畫實(shí)現(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);
}
左右橫移下劃線動畫特效
![OZGFLNYKPK]@CZIL~]_D(5Y.png](http://img.jbzj.com/file_images/article/202002/202002031530036.png)
主要利用js判斷鼠標(biāo)移開時(shí)的位置,對動畫效果的進(jìn)行左右移入移出顯示
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)簽進(jìn)行動畫效果的動畫實(shí)現(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實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨效果,本文圖文并茂實(shí)例代碼詳解,給大家介紹的非常詳細(xì),需要的朋友參考下吧2019-12-09
純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨的示例代碼
這篇文章主要介紹了純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨的示例代碼的相關(guān)資料,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-04-11
純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨滑動效果
這篇文章主要介紹了純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨滑動效果,需要的朋友可以參考下2018-03-29CSS中的下劃線text-decoration屬性使用進(jìn)階
這篇文章主要介紹了CSS中的下劃線text-decoration屬性使用進(jìn)階,文章前面則使用摘自w3cschool的基本使用知識進(jìn)行小回顧,需要的朋友可以參考下2015-08-12- 用過CSS hack的朋友應(yīng)該知道,用下劃線命名也是一種hack,如使用_style這樣的命名,可以讓IE外的大部分瀏覽器忽略這個(gè)樣式的定義。這篇文章主要為大家介紹了css布局命名時(shí)2014-06-16
- 下面為大家展示一個(gè)實(shí)例:未被點(diǎn)擊時(shí)超鏈接文字無下劃線,顯示為藍(lán)色;當(dāng)鼠標(biāo)在鏈接上時(shí)有下劃線,鏈接文字顯示為紅色;當(dāng)點(diǎn)擊鏈接后,鏈接無下劃線,顯示為綠色,感興趣的2013-06-21
本文主要介紹了純CSS實(shí)現(xiàn)了下劃線的交互動畫效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)2023-03-06




