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

目錄
切換開(kāi)關(guān)
過(guò)渡效果
一點(diǎn)JavaScript
首頁(yè) web前端 css教程 菜單揭示頁(yè)面旋轉(zhuǎn)動(dòng)畫(huà)

菜單揭示頁(yè)面旋轉(zhuǎn)動(dòng)畫(huà)

Apr 02, 2025 pm 01:47 PM

Menu Reveal By Page Rotate Animation

網(wǎng)站菜單設(shè)計(jì)方法多樣,有些菜單始終可見(jiàn),直接顯示所有選項(xiàng);另一些則隱藏起來(lái),需要點(diǎn)擊才能展開(kāi)。隱藏菜單的展開(kāi)方式也各有不同:有的滑出并覆蓋內(nèi)容,有的推開(kāi)內(nèi)容,有的則采用全屏顯示。

每種方法都有優(yōu)缺點(diǎn),最佳選擇取決于具體應(yīng)用場(chǎng)景。我個(gè)人通常更喜歡滑出式菜單,當(dāng)然并非所有情況都適用。但如果需要節(jié)省空間且易于訪(fǎng)問(wèn)的菜單,滑出式菜單很難被超越。

然而,滑出式菜單經(jīng)常與頁(yè)面內(nèi)容沖突。它至少會(huì)遮擋內(nèi)容,最壞則會(huì)完全從UI中移除內(nèi)容。

我嘗試了一種不同的方法,它兼具固定位置菜單的持久性和可用性,以及節(jié)省空間的隱藏式滑出菜單的特性,且不會(huì)將用戶(hù)從當(dāng)前內(nèi)容中移除。

下面是我的實(shí)現(xiàn)方法。

切換開(kāi)關(guān)

我們正在構(gòu)建一個(gè)具有兩種狀態(tài)(打開(kāi)和關(guān)閉)的菜單,并在兩者之間切換。這就是復(fù)選框技巧發(fā)揮作用的地方。它非常完美,因?yàn)閺?fù)選框具有兩種常見(jiàn)的交互狀態(tài)——選中和未選中(還有不確定狀態(tài))——可用于觸發(fā)這些狀態(tài)。

復(fù)選框隱藏在菜單圖標(biāo)下方,并使用CSS進(jìn)行定位,因此即使用戶(hù)與之交互,也看不到它。選中復(fù)選框(或者,咳咳,菜單圖標(biāo))會(huì)顯示菜單。取消選中則隱藏它。就這么簡(jiǎn)單。我們甚至不需要JavaScript來(lái)完成這項(xiàng)工作!

當(dāng)然,復(fù)選框技巧并不是唯一的方法,如果您想使用JavaScript切換類(lèi)來(lái)打開(kāi)和關(guān)閉菜單,那也完全沒(méi)問(wèn)題。

重要的是,復(fù)選框在源代碼中應(yīng)位于主要內(nèi)容之前,因?yàn)槲覀儗⒆罱K編寫(xiě)的:checked選擇器需要使用同級(jí)選擇器。如果這會(huì)引起布局問(wèn)題,請(qǐng)使用Grid或Flexbox進(jìn)行布局,因?yàn)樗鼈兣c源代碼順序無(wú)關(guān),就像我如何利用其優(yōu)勢(shì)進(jìn)行CSS計(jì)數(shù)一樣。

使用appearance CSS屬性去除復(fù)選框的默認(rèn)樣式(由瀏覽器添加),然后添加帶有菜單圖標(biāo)的偽元素,這樣用戶(hù)就看不到復(fù)選框的方塊。

首先,基本的標(biāo)記:

<input type="checkbox" id="menu-toggle">
<div id="page">
  <!-- 頁(yè)面內(nèi)容 -->
</div>
<div id="menu">
  <!-- 菜單內(nèi)容 -->
</div>

以及復(fù)選框技巧和菜單圖標(biāo)的基本CSS:

/* 隱藏復(fù)選框并重置樣式 */
input[type="checkbox"] {
  appearance: initial; /* 刪除方框 */
  border: 0; margin: 0; outline: none; /* 刪除默認(rèn)邊距、邊框和輪廓 */
  width: 30px; height: 30px; /* 設(shè)置菜單圖標(biāo)尺寸 */
  z-index: 1; /* 確保它位于頂部 */
}

/* 菜單圖標(biāo) */
input::after {
  content: "\2255";
  display: block;
  font: 25pt/30px "georgia";
  text-indent: 10px;
  width: 100%; height: 100%;
}

/* 頁(yè)面內(nèi)容容器 */
#page {
  background: url("earbuds.jpg") #ebebeb center/cover;
  width: 100%; height: 100%;
}

我還添加了#page內(nèi)容的樣式,它將是一個(gè)全尺寸背景圖像。

過(guò)渡效果

點(diǎn)擊菜單控件時(shí)會(huì)發(fā)生兩件事。首先,菜單圖標(biāo)更改為“×”標(biāo)記,表示可以點(diǎn)擊它來(lái)關(guān)閉菜單。因此,當(dāng)輸入處于:checked狀態(tài)時(shí),我們選擇復(fù)選框輸入的::after偽元素:

input:checked::after {
  content: "\00d7"; /* 更改為“×”標(biāo)記 */
  color: #ebebeb;
}

其次,主要內(nèi)容(我們的“耳機(jī)”圖像)進(jìn)行轉(zhuǎn)換,顯示下方的菜單。它向右移動(dòng)、旋轉(zhuǎn)并縮小,其左側(cè)角變?yōu)榻切巍_@是為了使內(nèi)容看起來(lái)像被推回,就像一個(gè)打開(kāi)的門(mén)。

input:checked ~ #page {
  clip-path: polygon(0 8%, 100% 0, 100% 100%, 0 92%);
  transform: translateX(40%) rotateY(10deg) scale(0.8);
  transform-origin: right center;
  transition: all .3s linear;
}

我使用clip-path來(lái)更改圖像的角。

由于我們正在對(duì)轉(zhuǎn)換應(yīng)用過(guò)渡,因此#page需要一個(gè)初始clip-path值,以便有東西可以進(jìn)行過(guò)渡。我們還將在#page上添加一個(gè)過(guò)渡,因?yàn)樗鼘⒃试S它像打開(kāi)一樣平滑地關(guān)閉。

#page {
  background: url("earbuds.jpeg") #ebebeb center/cover;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transition: all .3s linear;
  width: 100%; height: 100%;
}

我們基本上完成了核心設(shè)計(jì)和代碼。當(dāng)復(fù)選框取消選中(通過(guò)點(diǎn)擊“×”標(biāo)記)時(shí),耳機(jī)圖像上的轉(zhuǎn)換將自動(dòng)撤消,它將被帶回中心位置。

一點(diǎn)JavaScript

即使我們已經(jīng)得到了想要的東西,還有一件事可以提升用戶(hù)體驗(yàn):點(diǎn)擊(或點(diǎn)擊)#page元素時(shí)關(guān)閉菜單。這樣,用戶(hù)無(wú)需查找甚至使用“×”標(biāo)記即可返回內(nèi)容。

由于這僅僅是隱藏菜單的另一種方法,我們可以使用JavaScript。如果由于某種原因禁用了JavaScript?沒(méi)關(guān)系。它只是一個(gè)增強(qiáng)功能,不會(huì)阻止菜單在沒(méi)有它的情況下工作。

document.querySelector("#page").addEventListener('click', (e, checkbox = document.querySelector('input')) => {
  if (checkbox.checked) { checkbox.checked = false; e.stopPropagation(); }
});

這三行代碼的作用是在#page元素上添加一個(gè)點(diǎn)擊事件處理程序,如果復(fù)選框處于:checked狀態(tài),則取消選中復(fù)選框,從而關(guān)閉菜單。

我們一直在查看為垂直/縱向設(shè)計(jì)制作的演示,但根據(jù)我們正在使用的內(nèi)容,它在大屏幕尺寸下也能同樣有效。

這只是對(duì)典型滑出式菜單的一種方法或嘗試。動(dòng)畫(huà)打開(kāi)了大量的可能性,您可能還會(huì)想到其他幾十個(gè)想法。事實(shí)上,我很想聽(tīng)聽(tīng)(或者更好的是,看到)它們,所以請(qǐng)分享!

以上是菜單揭示頁(yè)面旋轉(zhuǎn)動(dòng)畫(huà)的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線(xiàn)人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話(huà)題

什么是'渲染障礙CSS”? 什么是'渲染障礙CSS”? Jun 24, 2025 am 12:42 AM

CSS會(huì)阻塞頁(yè)面渲染是因?yàn)闉g覽器默認(rèn)將內(nèi)聯(lián)和外部CSS視為關(guān)鍵資源,尤其是使用引入的樣式表、頭部大量?jī)?nèi)聯(lián)CSS以及未優(yōu)化的媒體查詢(xún)樣式。1.提取關(guān)鍵CSS并內(nèi)嵌至HTML;2.延遲加載非關(guān)鍵CSS通過(guò)JavaScript;3.使用media屬性?xún)?yōu)化加載如打印樣式;4.壓縮合并CSS減少請(qǐng)求。建議使用工具提取關(guān)鍵CSS,結(jié)合rel="preload"異步加載,合理使用media延遲加載,避免過(guò)度拆分與復(fù)雜腳本控制。

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

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

CSS教程,用于創(chuàng)建粘性標(biāo)頭或頁(yè)腳 CSS教程,用于創(chuàng)建粘性標(biāo)頭或頁(yè)腳 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

什么是圓錐級(jí)函數(shù)? 什么是圓錐級(jí)函數(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類(lèi)中的變量?jī)H對(duì)匹配該類(lèi)的元素及其子元素可用。最佳實(shí)踐包括:1.使用:root定義全局變量如主題色;2.在組件內(nèi)部定義局部變量以實(shí)現(xiàn)封裝;3.避免重復(fù)聲明同一變量;4.注意選擇器特異性可能引發(fā)的覆蓋問(wèn)題。此外,CSS變量區(qū)分大小寫(xiě),且應(yīng)在使用前定義以避免錯(cuò)誤。若變量未定義或引用失敗,則會(huì)采用回退值或默認(rèn)值initial。調(diào)試時(shí)可通過(guò)瀏覽器開(kāi)發(fā)者工

CSS教程專(zhuān)注于移動(dòng)優(yōu)先設(shè)計(jì) CSS教程專(zhuān)注于移動(dòng)優(yōu)先設(shè)計(jì) Jul 02, 2025 am 12:52 AM

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

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

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

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

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

See all articles