国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
滑動效果
背景動畫
錨點定位動畫
結(jié)合兩種效果
彈跳效果?為什么不呢?!
結(jié)論
首頁 web前端 css教程 使用錨定位的花式菜單導航

使用錨定位的花式菜單導航

Mar 07, 2025 pm 05:14 PM

Fancy Menu Navigation Using Anchor Positioning

CSS錨點定位功能想必您已有所耳聞,對吧?這項功能允許您將頁面上的任何元素鏈接到另一個元素,即錨點。它對所有工具提示都非常有用,但也能創(chuàng)造許多其他不錯的效果。

本文將研究菜單導航,我依靠錨點定位在鏈接上創(chuàng)建出色的懸停效果。

很酷,對吧?我們有一個滑動效果,藍色矩形通過流暢的過渡完美地適應文本內(nèi)容。如果您不熟悉錨點定位,此示例非常適合您,因為它很簡單,可以讓您了解這項新功能的基礎知識。我們還將學習另一個示例,所以請堅持到最后!

請注意,在我撰寫本文時,只有基于Chromium的瀏覽器完全支持錨點定位。在其他瀏覽器更廣泛地支持此功能之前,您需要在Chrome或Edge等瀏覽器中查看演示。

http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bhttp://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bhttp://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b 初始配置

讓我們從HTML結(jié)構(gòu)開始,它只是一個包含無序鏈接列表的nav元素:

<nav><ul>
<li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Home</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">About</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Projects</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Blog</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Contact</a></li>
  </ul></nav>

我們不會花太多時間解釋這個結(jié)構(gòu),因為如果您的用例不同,它也可能不同。只需確保語義與您嘗試執(zhí)行的操作相關即可。至于CSS部分,我們將從一些基本樣式開始,以創(chuàng)建水平菜單導航。

ul {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  gap: .5rem;
  font-size: 2.2rem;
}

ul li a {
  color: http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b000;
  text-decoration: none;
  font-weight: 900;
  line-height: 1.5;
  padding-inline: .2em;
  display: block;
}

到目前為止,沒有什么特別的。我們刪除了一些默認樣式并使用Flexbox將元素水平對齊。

滑動效果

首先,讓我們了解效果的工作原理。乍一看,似乎我們有一個矩形,它縮小到很小的高度,移動到懸停的元素,然后增長到全高。這就是視覺效果,但實際上,涉及多個元素!

這是我的第一個演示,我使用不同的顏色來更好地了解正在發(fā)生的事情。

每個菜單項都有其自己的“元素”可以收縮或增長。然后我們有一個公共“元素”(紅色的那個),它在不同的菜單項之間滑動。第一個效果是使用背景動畫完成的,第二個效果是錨點定位發(fā)揮作用的地方!

背景動畫

對于第一部分,我們將動畫化CSS漸變的高度:

/* 1 */
ul li {
  background: 
    conic-gradient(lightblue 0 0)
    bottom/100% 0% no-repeat;
  transition: .2s;
}

/* 2 */
ul li:is(:hover,.active) {
  background-size: 100% 100%;
  transition: .2s .2s;
}

/* 3 */
ul:has(li:hover) li.active:not(:hover) {
  background-size: 100% 0%;
  transition: .2s;
}

我們定義了一個寬度為100%,高度為0%的漸變,位于底部。漸變語法可能看起來很奇怪,但它是允許我擁有單色漸變的最短語法。

相關:“如何正確定義單色漸變”

然后,如果菜單項被懸?;蚓哂?active類,我們將高度設置為100%。請注意此處延遲的使用,以確保增長發(fā)生在收縮之后。

最后,我們需要處理.active項的特殊情況。如果我們懸停任何項(不是活動項),則.active項會獲得收縮效果(漸變高度等于0%)。這就是代碼中第三個選擇器的作用。

我們的第一個動畫完成了!請注意,由于我們在第二個選擇器中定義的延遲,增長是如何在收縮完成之后開始的。

錨點定位動畫

第一個動畫非常容易,因為每個項目都有自己的背景動畫,這意味著我們不必關心文本內(nèi)容,因為背景會自動填充整個空間。

我們將使用一個元素進行第二個動畫,該元素在所有菜單項之間滑動,同時調(diào)整其寬度以適應每個項目的文本。這就是錨點定位可以幫助我們的地方。

讓我們從以下代碼開始:

<nav><ul>
<li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Home</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">About</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Projects</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Blog</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Contact</a></li>
  </ul></nav>

為了避免添加額外的元素,我更喜歡在ul上使用偽元素。它應該是絕對定位的,我們將依靠兩個屬性來激活錨點定位。

我們使用anchor-name屬性定義錨點。當菜單項被懸停或具有.active類時,它將成為錨元素。如果另一個項目處于懸停狀態(tài),我們還必須從.active項目中刪除錨點(因此,代碼中的最后一個選擇器)。換句話說,一次只定義一個錨點。

然后我們使用position-anchor屬性將偽元素鏈接到錨點。請注意兩者如何使用相同的表示法--li。這類似于例如,我們?nèi)绾问褂锰囟Q定義@keyframes,然后在animation屬性中使用它。請記住,您必須使用語法,這意味著名稱必須始終以兩個破折號(--)開頭。

偽元素已正確放置,但什么也看不見,因為我們沒有定義任何維度!讓我們添加以下代碼:

ul {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  gap: .5rem;
  font-size: 2.2rem;
}

ul li a {
  color: http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b000;
  text-decoration: none;
  font-weight: 900;
  line-height: 1.5;
  padding-inline: .2em;
  display: block;
}

height屬性很簡單,但anchor()是新成員。以下是Juan Diego在Almanac中對其的描述:

CSS anchor()函數(shù)獲取錨元素的一側(cè)并解析為其定位的。它只能用于內(nèi)嵌屬性(例如top、bottom、bottom、left、right等),通常用于相對于錨點放置絕對定位的元素。

讓我們也查看MDN頁面:

anchor() CSS 函數(shù)可以在錨定位元素的內(nèi)嵌屬性值中使用,返回相對于其關聯(lián)錨元素邊緣位置的長度值。

通常,我們使用left: 0將絕對元素放置在其包含塊(即具有position: relative的最近祖先)的左邊緣。left: anchor(left)將執(zhí)行相同的操作,但它將考慮關聯(lián)的錨元素,而不是包含塊。

就是這樣——我們完成了!在下面的演示中懸停菜單項,看看偽元素是如何在它們之間滑動的。

每次您將鼠標懸停在菜單項上時,它都會成為偽元素(ul:before)的新錨點。這也意味著anchor(...)值將發(fā)生變化,從而產(chǎn)生滑動效果!讓我們不要忘記使用transition,否則我們將有一個突然的變化。

我們也可以這樣編寫代碼:

<nav><ul>
<li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Home</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">About</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Projects</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Blog</a></li>
    <li><a href="http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">Contact</a></li>
  </ul></nav>

換句話說,我們可以依靠inset簡寫,而不是使用left、right和bottom等物理屬性,并且代替定義position-anchor,我們可以在anchor()函數(shù)中包含錨點的名稱。我們在這里重復了三次相同的名稱,這可能不是最佳選擇,但在某些情況下,您可能希望您的元素考慮多個錨點,在這種情況下,此語法將很有意義。

結(jié)合兩種效果

現(xiàn)在,我們將兩種效果結(jié)合起來,,幻覺完美了!

請注意transition值,其中延遲很重要:

ul {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  gap: .5rem;
  font-size: 2.2rem;
}

ul li a {
  color: http://m.miracleart.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b000;
  text-decoration: none;
  font-weight: 900;
  line-height: 1.5;
  padding-inline: .2em;
  display: block;
}

我們有一系列三個動畫——縮小漸變的高度、滑動偽元素和增大漸變的高度——因此我們需要在它們之間設置延遲才能將所有內(nèi)容組合在一起。這就是為什么對于偽元素的滑動,我們有一個等于一個動畫持續(xù)時間的延遲(transition: .2 .2s),而對于增長部分,延遲等于持續(xù)時間的兩倍(transition: .2s .4s)。

彈跳效果?為什么不呢?!

讓我們嘗試另一個奇特的動畫,其中高亮矩形變形為一個小圓圈,跳到下一個項目,然后再次變形回矩形!

我不會過多解釋這個例子,因為這是你剖析代碼的作業(yè)!我將提供一些提示,以便您可以解包正在發(fā)生的事情。

與之前的效果一樣,我們結(jié)合了兩個動畫。對于第一個,我將使用每個菜單項的偽元素,我將調(diào)整尺寸和border-radius來模擬變形。對于第二個動畫,我將使用ul偽元素創(chuàng)建一個小的圓圈,我將它移動到菜單項之間。

這是另一個版本的演示,顏色不同,過渡速度較慢,以便更好地可視化每個動畫:

棘手的部分是跳躍效果,我使用了一個奇怪的cubic-bezier(),但我有一篇詳細的文章在我的CSS-Tricks文章“使用cubic-bezier()的先進CSS動畫”中解釋了這種技術。

結(jié)論

我希望您喜歡使用錨點定位功能進行的這個小實驗。我們只查看了三個屬性/值,但這足以讓您準備好使用這項新功能。anchor-name和position-anchor屬性是將一個元素(在此上下文中通常稱為“目標”元素)鏈接到另一個元素(在此上下文中我們稱為“錨”元素)的強制性部分。從那里,您可以使用anchor()函數(shù)來控制位置。

相關:CSS錨點定位指南

以上是使用錨定位的花式菜單導航的詳細內(nèi)容。更多信息請關注PHP中文網(wǎng)其他相關文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權歸原作者所有,本站不承擔相應法律責任。如您發(fā)現(xiàn)有涉嫌抄襲侵權的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

什么是AutoPrefixer,它如何工作? 什么是AutoPrefixer,它如何工作? Jul 02, 2025 am 01:15 AM

Autoprefixer是一個根據(jù)目標瀏覽器范圍自動為CSS屬性添加廠商前綴的工具。1.它解決了手動維護前綴易出錯的問題;2.通過PostCSS插件形式工作,解析CSS、分析需加前綴的屬性、依配置生成代碼;3.使用步驟包括安裝插件、設置browserslist、在構(gòu)建流程中啟用;4.注意事項有不手動加前綴、保持配置更新、非所有屬性都加前綴、建議配合預處理器使用。

CSS教程,用于創(chuàng)建粘性標頭或頁腳 CSS教程,用于創(chuàng)建粘性標頭或頁腳 Jul 02, 2025 am 01:04 AM

TocreatestickyheadersandfooterswithCSS,useposition:stickyforheaderswithtopvalueandz-index,ensuringparentcontainersdon’trestrictit.1.Forstickyheaders:setposition:sticky,top:0,z-index,andbackgroundcolor.2.Forstickyfooters,betteruseposition:fixedwithbot

什么是圓錐級函數(shù)? 什么是圓錐級函數(shù)? Jul 01, 2025 am 01:16 AM

theconic-Gradient()functionIncsscreatesCircularGradientsThatRotateColorStopSaroundAcentralPoint.1.IsidealForPieCharts,ProgressIndicators,colordichers,colorwheels和decorativeBackgrounds.2.itworksbysbysbysbydefindefingincolordefingincolorstopsatspecificains off.

CSS自定義屬性的范圍是什么? CSS自定義屬性的范圍是什么? Jun 25, 2025 am 12:16 AM

CSS自定義屬性的作用域取決于其聲明的上下文,全局變量通常定義在:root中,而局部變量則定義在特定選擇器內(nèi),以便組件化和隔離樣式。例如,定義在.card類中的變量僅對匹配該類的元素及其子元素可用。最佳實踐包括:1.使用:root定義全局變量如主題色;2.在組件內(nèi)部定義局部變量以實現(xiàn)封裝;3.避免重復聲明同一變量;4.注意選擇器特異性可能引發(fā)的覆蓋問題。此外,CSS變量區(qū)分大小寫,且應在使用前定義以避免錯誤。若變量未定義或引用失敗,則會采用回退值或默認值initial。調(diào)試時可通過瀏覽器開發(fā)者工

CSS教程,用于創(chuàng)建加載旋轉(zhuǎn)器和動畫 CSS教程,用于創(chuàng)建加載旋轉(zhuǎn)器和動畫 Jul 07, 2025 am 12:07 AM

創(chuàng)建CSS加載旋轉(zhuǎn)器的方法有三種:1.使用邊框的基本旋轉(zhuǎn)器,通過HTML和CSS實現(xiàn)簡單動畫;2.使用多個點的自定義旋轉(zhuǎn)器,通過不同延遲時間實現(xiàn)跳動效果;3.在按鈕中添加旋轉(zhuǎn)器,通過JavaScript切換類來顯示加載狀態(tài)。每種方法都強調(diào)了設計細節(jié)如顏色、大小、可訪問性和性能優(yōu)化的重要性,以提升用戶體驗。

CSS教程專注于移動優(yōu)先設計 CSS教程專注于移動優(yōu)先設計 Jul 02, 2025 am 12:52 AM

Mobile-firstCSSdesignrequiressettingtheviewportmetatag,usingrelativeunits,stylingfromsmallscreensup,optimizingtypographyandtouchtargets.First,addtocontrolscaling.Second,use%,em,orreminsteadofpixelsforflexiblelayouts.Third,writebasestylesformobile,the

如何將整個網(wǎng)格集中在視口中? 如何將整個網(wǎng)格集中在視口中? Jul 02, 2025 am 12:53 AM

要讓整個網(wǎng)格布局在視口中居中顯示,可通過以下方法實現(xiàn):1.使用margin:0auto實現(xiàn)水平居中,需設定容器固定寬度,適用于固定布局;2.利用Flexbox在外層容器設置justify-content和align-items屬性,結(jié)合min-height:100vh可實現(xiàn)垂直和水平居中,適合全屏展示場景;3.直接使用CSSGrid的place-items屬性在父容器上快速居中,簡潔且現(xiàn)代瀏覽器支持良好,同時需確保父容器有足夠高度。每種方式均有適用場景和限制,根據(jù)實際需求選擇合適的方案即可。

如何創(chuàng)建本質(zhì)上響應的網(wǎng)格布局? 如何創(chuàng)建本質(zhì)上響應的網(wǎng)格布局? Jul 02, 2025 am 01:19 AM

要創(chuàng)建內(nèi)在響應式網(wǎng)格布局,核心方法是使用CSSGrid的repeat(auto-fit,minmax())模式;1.設置grid-template-columns:repeat(auto-fit,minmax(200px,1fr))讓瀏覽器自動調(diào)整列數(shù)并限制每列最小和最大寬度;2.使用gap控制格子間距;3.容器應設為相對單位如width:100%、配合box-sizing:border-box避免寬度計算錯誤并用margin:auto居中;4.可選設置行高與內(nèi)容對齊方式提升視覺一致性,如row

See all articles