Maison > interface Web > tutoriel CSS > Comment créer un menu radial en CSS sans images ni bibliothèques ?

Comment créer un menu radial en CSS sans images ni bibliothèques ?

DDD
Libérer: 2024-11-10 08:44:02
original
543 Les gens l'ont consulté

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

Comment créer un menu radial en CSS

Introduction

Les menus radiaux, avec leurs La disposition circulaire unique des options offre un moyen intuitif et visuellement attrayant d'accéder aux commandes ou de naviguer dans le contenu. Dans cet article, nous aborderons les techniques de création d'un menu radial à l'aide de CSS, sans recourir à des images ou à des bibliothèques tierces.

Structure HTML

Nous Je vais commencer par une structure HTML simple composée d'une case à cocher de saisie (pour basculer la visibilité du menu), d'une étiquette (pour le bouton central) et d'une liste non ordonnée (pour le menu radial éléments).

<input type='checkbox'>
Copier après la connexion

Implémentation CSS

Maintenant, nous allons styliser notre menu radial en utilisant CSS. Le code suivant présente une version révisée, tenant compte des commentaires et intégrant des améliorations stylistiques.

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;
}
Copier après la connexion

Explication

  • Case à cocher : Lorsque cette case est cochée , la case à cocher bascule la visibilité du radial menu.
  • Étiquette : L'étiquette est positionnée comme le bouton central et contient l'icône d'étoile de déclenchement.
  • Structure du menu radial : La liste non ordonnée contient les éléments de menu sous forme d'éléments de liste («li») avec leurs ancres respectives ("a").
  • Transformations : Nous utilisons des transformations CSS pour créer la disposition radiale en faisant pivoter et en inclinant les éléments.
  • Ombres et dégradés : Les ombres et les dégradés radiaux donnent aux boutons et aux éléments de menu un effet 3D.
  • Pseudo Éléments : Les pseudo-éléments créent l'illusion de profondeur et de bords arrondis.

Cette démonstration améliorée présente toutes les fonctionnalités du menu radial, avec des coins arrondis, des effets d'ombrage et des astuces facultatives pour indiquer le article actif.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal