搜索
首页web前端css教程魔法冬境——冬至之旅

魔法冬境——冬至之旅

Dec 27, 2024 pm 01:52 PM

这是前端挑战赛 - 12 月版的提交,Glam Up My Markup:冬至

注: 在这个项目的开发过程中,我注意到冬至的主题也启发了其他挑战者。这突显了这个季节的自然和魔力是多么鼓舞人心。我的灵感来自于我个人对冬天的憧憬,注重细节并诠释它的魅力。我希望这个项目能够为这一挑战中的想法多样性做出贡献。

我建造了什么

冬至魔法”是一个交互式网络场景,旨在捕捉冬至的本质和魅力。该项目具有太阳、月亮、星星、北极光、飘落的雪花等动画元素,以及其他节日元素,如发光的火焰、闪烁的灯光和射出的彗星。目标是创造一种视觉上引人入胜的体验,让观众沉浸在冬季的魔力中,同时展示现代网络技术的力量。

演示

您可以在这里现场体验该项目:冬至魔法演示

完整的代码可以在这里:



    
    
    <title>冬至场景</title>
    
        身体 {
            保证金:0;
            溢出:隐藏;
            背景:线性渐变(到底部,#003366,#000);
            显示:柔性;
            调整内容:居中;
            对齐项目:居中;
            高度:100vh;
            颜色: 白色;
            字体系列:Arial、无衬线字体;
        }

        .天空{
            位置:绝对;
            顶部:0;
            左:0;
            宽度:100%;
            高度:100%;
            背景:线性渐变(到顶部,#1e3c72,#2a5298);
            z 索引:-1;
            动画:skyTransition 20s无限交替;
        }

        。太阳 {
            位置:绝对;
            宽度:80px;
            高度:80像素;
            背景:径向渐变(圆形,#ffcc00,#ff9900);
            边界半径:50%;
            动画:moveSun 8s 无限;
            z 索引:1;
        }

        。月亮 {
            位置:绝对;
            宽度:60 像素;
            高度:60 像素;
            背景:径向渐变(圆,#ffffff,#cccccc);
            边界半径:50%;
            动画:moveMoon 8s 无限;
            z 索引:1;
            不透明度:0.8;
        }

        .星星{
            位置:绝对;
            顶部:0;
            左:0;
            宽度:100%;
            高度:100%;
            指针事件:无;
            z 索引:0;
        }

        。星星 {
            位置:绝对;
            宽度:3px;
            高度:3px;
            背景:白色;
            边界半径:50%;
            不透明度:0;
            动画:闪烁3秒无限;
        }

        .极光{
            位置:绝对;
            顶部:0;
            左:0;
            宽度:100%;
            高度:100%;
            背景:径向渐变(圆形,rgba(0,255,150,0.3),透明);
            不透明度:0.4;
            动画:auroraEffect 10s无限交替;
            z 索引:-1;
        }

        .彗星{
            位置:绝对;
            宽度:10px;
            高度:10px;
            背景:径向渐变(圆形,#ffffff,透明);
            边界半径:50%;
            框阴影:0 0 10px 5px #ffffff;
            不透明度:0.8;
            动画:flyComet 6s 无限;
        }

        .light-string {
            位置:绝对;
            底部:10%;
            宽度:100%;
            显示:柔性;
            justify-content:空间均匀;
        }。光 {
            宽度:15 像素;
            高度:15px;
            背景:红色;
            边界半径:50%;
            动画:blinkLight 2s无限交替;
        }

        。标题 {
            位置:绝对;
            顶部:50%;
            左:50%;
            变换:翻译(-50%,-50%);
            字体大小:3.5rem;
            font-family: 'Cinzel Decorative',草书;
            颜色:#ffddcc;
            文本阴影:3px 3px 10px #000;
            不透明度:0;
            动画:fadeInOut 10s 无限;
        }

        。火 {
            位置:绝对;
            底部:5%;
            左:50%;
            变换:translateX(-50%);
            宽度:50px;
            高度:100px;
            背景:径向渐变(圆形, rgba(255, 165, 0, 1), rgba(255, 69, 0, 0.7));
            边界半径:50%;
            动画:无限闪烁0.5s;
        }

        @关键帧闪烁{
            0%, 100% {
                变换:缩放(1);
                不透明度:0.8;
            }
            50% {
                变换:缩放(1.2);
                不透明度:1;
            }
        }

        。树 {
            位置:绝对;
            底部:10%;
            左: calc(10% var(--position, 0%));
            宽度:40px;
            高度:60 像素;
            背景:线性渐变(到底部,#228B22,#006400);
            剪辑路径:多边形(50% 0%、0% 100%、100% 100%);
        }

        @keyframes fadeInOut {
            0%, 100% {
                不透明度:0;
            }
            50% {
                不透明度:1;
            }
        }

        @keyframes moveSun {
            0% {
                顶部:80%;
                左:10%;
            }
            50% {
                顶部:20%;
                左:50%;
            }
            100% {
                顶部:80%;
                左:90%;
            }
        }

        @keyframes moveMoon {
            0% {
                顶部:20%;
                左:90%;
            }
            50% {
                顶部:10%;
                左:50%;
            }
            100% {
                顶部:20%;
                左:10%;
            }
        }

        @keyframes skyTransition {
            0% {
                背景:线性渐变(到顶部,#1e3c72,#2a5298);
            }
            50% {
                背景:线性渐变(到顶部,#000428,#004e92);
            }
            100% {
                背景:线性渐变(到顶部,#2c3e50,#4ca1af);
            }
        }

        @关键帧闪烁{
            0%, 100% {
                不透明度:0;
            }
            50% {
                不透明度:1;
            }
        }

        @keyframes auroraEffect {
            0% {
                变换:translateX(-20px) 缩放(1.2);
            }
            100% {
                变换:translateX(20px) 缩放(1.5);
            }}

        @keyframes 飞彗星 {
            0% {
                顶部:-10%;
                左:110%;
            }
            100% {
                顶部:110%;
                左:-10%;
            }
        }

        @keyframes眨眼灯{
            0% {
                背景:红色;
            }
            100% {
                背景:黄色;
            }
        }

    风格>
    <link href="https://fonts.googleapis.com/css2?family=Cinzel%20%E8%A3%85%E9%A5%B0:wght@400;700&display=swap" rel="stylesheet">
头>

    <div>



<p>下面是该项目的预览图:</p>

<p><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/000/000/173527873830508.jpg?x-oss-process=image/resize,p_40" class="lazy" alt="Enchanted Winter Realms - A Journey Through the Solstice"></p>

<h2>
  
  
  旅行
</h2>

<p>创作“冬至魔法”是一个令人兴奋且充满挑战的过程。以下是我的旅程概述:</p>

<h2>
  
  
  想法
</h2>

<p>我想通过身临其境的网络体验将冬至的美丽和神秘带入生活。该项目的灵感来自冬季的自然元素以及这个季节宁静而充满活力的氛围。</p>

<h2>
  
  
  使用的技术
</h2>

<ul>
<li>基本结构的 HTML。</li>
<li>用于动画、渐变和样式的 CSS。</li>
<li>用于动态交互的 JavaScript,包括雪花、星星和彗星的生成。</li>
<li>Google Fonts 使用“Cinzel Decorative”字体增强标题文本的美感。</li>
</ul>

<h2>
  
  
  主要特点
</h2>

<p><strong>动态背景:</strong> <em>天空在渐变之间平滑过渡,以模仿一天中的不同时间。</em></p>

<p><strong>互动元素:</strong> <em>星星闪烁、雪花飘落、彗星划过屏幕,为场景增添生机。</em></p>

<p><strong>节日详情:</strong> <em>闪烁的灯光和炽热的火焰增强了季节的魅力。</em></p>

<p><strong>辅助功能:</strong> <em>该项目的设计具有视觉吸引力且轻量级,确保其跨设备无缝运行。</em></p>

<h2>
  
  
  挑战和经验教训
</h2>

<p>其中一项挑战是优化动画以确保在各种设备上的流畅性能。我学到了很多关于使用 CSS 和 JavaScript 管理动画性能的知识。我特别自豪的是多个动画元素的无缝集成,而不影响页面的响应能力。</p>

<h2>
  
  
  下一步是什么
</h2>

<p>未来,我希望:</p>

<p>添加音频元素,例如微妙的冬季主题背景音乐或音效。</p>

<p>引入用户交互性,允许观看者自定义场景的各个方面。</p>

<p>将项目扩展为具有不同季节主题的系列。</p>
<h2>
  
  
  执照
</h2>

<p>该项目的代码已获得 MIT 许可证的许可,使其免费开放给任何人使用或改编。</p>

<h2>
  
  
  致谢
</h2>

<p>特别感谢 <strong>DEV 社区</strong>主办本次挑战并通过他们的平台提供灵感。感谢您考虑我的提交!我希望您喜欢“<strong><em>冬至魔法</em></strong>。”</p>


          </div>

            
        

以上是魔法冬境——冬至之旅的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
什么是CSS网格?什么是CSS网格?Apr 30, 2025 pm 03:21 PM

CSS网格是创建复杂,响应式Web布局的强大工具。它简化了设计,提高可访问性并提供了比旧方法更多的控制权。

什么是CSS Flexbox?什么是CSS Flexbox?Apr 30, 2025 pm 03:20 PM

文章讨论了CSS FlexBox,这是一种布局方法,用于有效地对齐和分布响应设计中的空间。它说明了FlexBox用法,将其与CSS网格进行了比较,并详细浏览了浏览器支持。

我们如何使用CSS使网站迅速响应?我们如何使用CSS使网站迅速响应?Apr 30, 2025 pm 03:19 PM

本文讨论了使用CSS创建响应网站的技术,包括视口元标签,灵活的网格,流体媒体,媒体查询和相对单元。它还涵盖了使用CSS网格和Flexbox一起使用,并推荐CSS框架

CSS盒装属性有什么作用?CSS盒装属性有什么作用?Apr 30, 2025 pm 03:18 PM

本文讨论了CSS盒装属性,该属性控制了元素维度的计算方式。它解释了诸如Content-Box,Border-Box和Padding-Box之类的值,以及它们对布局设计和形式对齐的影响。

我们如何使用CSS动画?我们如何使用CSS动画?Apr 30, 2025 pm 03:17 PM

文章讨论使用CSS,关键属性并与JavaScript结合创建动画。主要问题是浏览器兼容性。

我们可以使用CSS向我们的项目添加3D转换吗?我们可以使用CSS向我们的项目添加3D转换吗?Apr 30, 2025 pm 03:16 PM

文章讨论了Web项目的3D转换,关键属性,浏览器兼容性和性能注意事项的讨论。(角色计数:159)

我们如何在CSS中添加梯度?我们如何在CSS中添加梯度?Apr 30, 2025 pm 03:15 PM

文章讨论了使用CSS梯度(线性,径向,重复)来增强网站视觉效果,添加深度,焦点和现代美学。

CSS中的伪元素是什么?CSS中的伪元素是什么?Apr 30, 2025 pm 03:14 PM

文章讨论了CSS中的伪元素,它们在增强HTML样式方面的使用以及与伪级的差异。提供实用的例子。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具