一键复制:期末大作业常用的CSS动画导航效果!

简介: 一键复制:期末大作业常用的CSS动画导航效果!

先上效果

   



🌟一个具有创意的导航菜单不仅能为你的大作业增色,还能展示你的技术实力。本文将分享一系列常用于期末大作业的CSS动画导航效果,这些效果不仅外观酷炫,而且易于实现。我们提供了一键复制的代码,让你能够快速集成到自己的项目中,节省时间,提高效率,让你的期末大作业脱颖而出。

   

完整代码

   

HTML

<nav>
         <!-- 导航栏按钮,用于主要页面导航 -->
         <nav>
             <!-- 主页按钮,包含文本和图标表示 -->
             <button type="button" title="Home">
                 <span>Home</span>
                 <!-- 使用Material Symbols Outline图标的HTML代码,用于增强视觉效果 -->
                 <span class="material-symbols-outlined" aria-hidden="true">首页</span>
                 <!-- SVG图形用于呈现"Home"文本的视觉效果,aria-hidden属性表示此元素不用于屏幕阅读器 -->
                 <svg viewBox="0 0 300 300" aria-hidden="true">
                     <g>
                         <!-- 使用textPath元素将文本沿着路径绘制 -->
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath">Home</textPath>
                         </text>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath" startOffset="50%">Home</textPath>
                         </text>
                     </g>
                 </svg>
             </button>
             <!-- 关于按钮,包含文本和图标表示 -->
             <button type="button">
                 <span>About</span>
                 <span class="material-symbols-outlined" aria-hidden="true">信息</span>
                 <svg viewBox="0 0 300 300" aria-hidden="true">
                     <g>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath">About</textPath>
                         </text>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath" startOffset="50%">About</textPath>
                         </text>
                     </g>
                 </svg>
             </button>
             <!-- 服务按钮,包含文本和图标表示 -->
             <button type="button">
                 <span>Services</span>
                 <span class="material-symbols-outlined" aria-hidden="true">服务</span>
                 <svg viewBox="0 0 300 300" aria-hidden="true">
                     <g>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath">Services</textPath>
                         </text>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath" startOffset="50%">Services</textPath>
                         </text>
                     </g>
                 </svg>
             </button>
             <!-- 联系按钮,包含文本和图标表示 -->
             <button type="button">
                 <span>concat</span>
                 <span class="material-symbols-outlined" aria-hidden="true">联系</span>
                 <svg viewBox="0 0 300 300">
                     <g>
                         <text fill="currentColor" aria-hidden="true">
                             <textPath xlink:href="#circlePath">Contact</textPath>
                         </text>
                         <text fill="currentColor">
                             <textPath xlink:href="#circlePath" startOffset="50%">Contact</textPath>
                         </text>
                     </g>
                 </svg>
             </button>
         </nav>
         <!-- SVG 模板与动态文本 -->
         <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
             viewBox="0 0 300 300" width="0" height="0">
             <defs>
                 <path id="circlePath" d="M 150, 150 m -50, 0 a 50,50 0 0,1 100,0 a 50,50 0 0,1 -100,0" />
             </defs>
         </svg>

CSS代码:


* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
/* 重置按钮样式 */
button {
    appearance: none;
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    color: inherit;
    text-decoration: none;
    text-transform: none;
    line-height: normal;
    overflow: visible;
}
body {
    min-height: 100svh;
    background-color: rgb(15, 23, 42);
    color: white;
    display: grid;
    place-content: center;
    font-size: 1rem;
    font-family: system-ui;
}
nav {
    --_clr-txt: rgb(255, 255, 255);
    --_clr-txt-svg: rgb(147, 158, 184);
    --_ani-speed: 6s;
    /* 旋转文本的速度 */
    display: flex;
    /*flex-wrap: wrap;*/
    gap: 1rem;
    font-size: 1.4rem;
}
nav>button {
    position: relative;
    display: grid;
    place-content: center;
    grid-template-areas: 'stack';
    padding: 0 1.5rem;
    text-transform: uppercase;
    font-weight: 300;
}
/* 将按钮元素堆叠在一起 */
nav>button>span {
    transition: all 300ms ease-in-out;
    grid-area: stack;
}
/* 导航图标 */
nav>button>span:last-of-type {
    margin-top: 0.25rem;
    transform: scale(0);
    transition-delay: 0ms;
    border-radius: 50%;
}
/* 悬停 - 隐藏文本 */
nav>button:focus-visible>span:first-of-type,
nav>button:hover>span:first-of-type {
    transform: scale(0);
}
/* 悬停 - 显示图标 */
nav>button:focus-visible>span:last-of-type,
nav>button:hover>span:last-of-type {
    transform: scale(1);
}
/* 导航 SVG 圆形文本 */
nav>button>svg {
    position: absolute;
    width: 200px;
    height: 200px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transform-origin: center;
    opacity: 0;
    text-transform: uppercase;
    transition: all 300ms ease-in-out;
    color: var(--_clr-txt-svg);
}
/* 悬停 - 显示旋转的 SVG */
nav>button:focus-visible>svg,
nav>button:hover>svg {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
    transition-delay: 150ms;
    transition: all 300ms ease-in-out;
}
/*
@supports (-webkit-touch-callout: none) {
/* 特定于 iOS 设备 * /
button svg {
/* 调整 iOS 设备的位置 * /
translate: -50% -50%;
animation: rotate var(--_ani-speed) linear infinite;
}
}
@supports not (-webkit-touch-callout: none) {
*/
button svg g {
    transform-origin: center;
    animation: rotate var(--_ani-speed) linear infinite;
}
@keyframes rotate {
    0% {
        transform: rotate(0deg);
    }
    100% {
        transform: rotate(360deg);
    }
}
相关文章
|
1月前
|
机器学习/深度学习 前端开发 JavaScript
|
23天前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
|
2天前
|
Web App开发 前端开发 JavaScript
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
6 1
|
28天前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
24 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
2月前
|
JavaScript 前端开发
JS配合CSS3实现动画和拖动小星星小Demo
本文通过代码示例展示了如何使用JavaScript和CSS3实现动画效果和拖动小星星的交互效果,包括文字掉落动画和鼠标拖动产生小星星动画的实现方法。
44 0
JS配合CSS3实现动画和拖动小星星小Demo
|
1月前
|
前端开发
CSS 动画介绍及语法
CSS 动画介绍及语法
27 0
|
3月前
|
前端开发 UED 开发者
有趣的CSS - 文字加载动画效果
这个文本加载动画简单而有趣,可以在网站标题、广告标语或者关键信息的展示上吸引用户的注意力。开发者可以根据需要调整动画的持续时间、步骤数,或者光标颜色等,来适应特定的设计需求。使用这种动态元素,增强网站的互动性和用户体验,同时也为网站增添了一抹活泼的风格。
72 5
|
3月前
|
前端开发
2s 利用 HTML+css动画实现企业官网效果
2s 利用 HTML+css动画实现企业官网效果
HTML+CSS 实现通用的企业官网页面(记得收藏)
HTML+CSS 实现通用的企业官网页面(记得收藏)

热门文章

最新文章