一键复制:期末大作业常用的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);
    }
}
目录
打赏
0
0
1
0
15
分享
相关文章
CSS 过渡和动画
CSS过渡和动画是用于为网页元素添加动态效果的两种重要技术
132 73
|
3月前
css3 svg制作404页面动画效果HTML源码
css3 svg制作404页面动画效果HTML源码
74 34
|
3月前
jQuery+CSS3实现404背景游戏动画源码
jQuery+CSS3实现404背景游戏动画源码
66 22
|
5月前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
92 31
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
94 6
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
124 7
|
5月前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
53 2

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等