首頁 >web前端 >css教學 >如何在沒有圖像或庫的情況下用 CSS 建立徑向選單?

如何在沒有圖像或庫的情況下用 CSS 建立徑向選單?

DDD
DDD原創
2024-11-10 08:44:02508瀏覽

How to Build a Radial Menu in CSS Without Images or Libraries?

如何在CSS 中建立徑向選單

簡介

徑向菜單及其獨特的圓形選項排列,提供了一種直觀且視覺上吸引人的方式來存取命令或瀏覽內容。在本文中,我們將深入研究使用 CSS 建立徑向選單的技術,而不依賴圖片或第三方函式庫。

HTML 結構

我們將從一個簡單的HTML 結構開始,其中包含一個輸入複選框(用於切換選單可見性)、一個標籤(用於中央按鈕)和一個無序列表(用於徑向選單項目)。

<input type='checkbox'>

CSS 實作

現在,我們將使用 CSS 設計徑向選單的樣式。以下程式碼示範了修訂版本,解決了回饋問題並合併了風格增強功能。

input {
    transform: translate(-100vw);
    visibility: hidden;
}

input:checked ~ ul {
    transform: scale(1); 
    opacity: .999;
    transition: .5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

label, ul, li {
    position: absolute;
    left: 50%;
    bottom: 50%;
}

label, a {
    color: #858596;
    font: 700 1em/ 2em sans-serif;
    text-align: center;
    text-shadow: 0 1px 1px #6c6f7e;
    cursor: pointer;
}

label {
    z-index: 2;
    margin: -1em;
    width: 2em;
    height: 2em;
    border-radius: 50%;
    box-shadow: 0 0 1px 1px white,  0 .125em .25em #876366,  0 .125em .5em #876366;
    background: #d3d3d3;
    background: -webkit-radial-gradient(#d4c7c5, #e5e1dd);
    background: radial-gradient(#d4c7c5, #e5e1dd);
}

ul {
    z-index: 1;
    margin: -10em 0;
    padding: 0;
    list-style: none;
    transform-origin: 50% -13em;
    transform: scale(0.001); 
    will-change: transform;
    opacity: .001;
    filter: drop-shadow(0 0.125em 0.25em #847c77);
    transition: 0.5s cubic-bezier(0.6, -0.28, 0.735, 0.045);
}
ul:before, ul:after {
    position: absolute;
    margin: -3em -0.25em;
    width: 0.5em;
    height: 3em;
    transform-origin: 50% 100%;
    background: #d3d3d3;
    background: -webkit-linear-gradient(#ddd, #c9c4bf);
    background: linear-gradient(#ddd, #c9c4bf);
    content: '';
}
ul:before {
    border-radius: 0.5em 0 0 0.5em;
    transform: rotate(-22.5deg) translate(-0.25em, -13em);
    box-shadow: inset 1px 0 1px #eee;
}
ul:after {
    border-radius: 0 0.5em 0.5em 0;
    transform: rotate(22.5deg) translate(0.25em, -13em);
    box-shadow: inset -1px 0 1px #eee;
}

li {
    overflow: hidden;
    width: 16em;
    height: 16em;
    transform-origin: 0 100%;
}
li:nth-child(1) {
    transform: rotate(-22.625deg) skewY(-75deg) scaleX(0.25882);
}
li:nth-child(2) {
    transform: rotate(-7.5deg) skewY(-75deg) scaleX(0.25882);
}
li:nth-child(2) a:after {
    position: absolute;
    top: 3em;
    left: 50%;
    margin: -0.375em;
    width: 0.75em;
    height: 0.75em;
    transform: rotate(45deg);
    box-shadow: inset -1px -1px 1px #eee;
    background: -webkit-linear-gradient(135deg, #bbb, #c9c4bf 50%);
    background: linear-gradient(-45deg, #bbb, #c9c4bf 50%);
    content: '';
}
li:nth-child(3) {
    transform: rotate(7.625deg) skewY(-75deg) scaleX(0.25882);
}
li a, li:before {
    margin: 0 -16em;
    width: 32em;
    height: 32em;
    border-radius: 50%;
}
li:before, li:after {
    position: absolute;
    border-radius: 50%;
    transform: scaleX(3.8637) skewY(75deg);
    content: '';
}
li:before {
    box-shadow: inset 0 0 1px 1px #fff, inset 0 0 3em #ebe7e2, inset 0 0 1px 2.9375em #c9c4bf, inset 0 0 0 3em #dcdcdc;
}
li:after {
    top: 100%;
    left: 0;
    margin: -13em;
    width: 26em;
    height: 26em;
    border-radius: 50%;
}

a {
    display: block;
    transform: scaleX(3.8637) skewY(75deg) rotate(7.5deg);
    line-height: 3em;
    text-align: center;
    text-decoration: none;
}

說明

  • 複選框: 勾選時,複選框切換徑向選單的可見度。
  • 標籤: 標籤位於中央按鈕並包含觸發星形圖示。
  • 徑向選單結構: 無序列表包含作為清單元素 ('li') 的選單項目及其各自的錨點 ('a')。
  • 轉換: 我們使用 CSS 轉換來透過旋轉和傾斜元素來建立徑向佈局。
  • 陰影和漸變:陰影和徑向漸變為按鈕和選單項目提供 3D 效果。
  • 偽元素:偽元素創造深度和圓邊的錯覺。

這個改進的演示展示了徑向選單的完整功能,包括圓角、陰影效果和用於指示選單的可選提示。活動項目。

以上是如何在沒有圖像或庫的情況下用 CSS 建立徑向選單?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn