HTML+CSS+JS制作圣诞祝福网页教程(附源码)

编程狮W3Cschool 2024-11-28 10:02:37 浏览数 (2984)
反馈

简介

在这个教程中,我们将学习如何使用HTML、CSS和JavaScript来创建一个充满节日气氛的圣诞祝福网页。这个网页将包括一个动态的圣诞树、飘落的雪花和闪烁的装饰物,以及一个显示“圣诞快乐!”的消息。

圣诞节祝福代码、雪花、圣诞树源码

准备工作

在开始之前,请确保你有基本的HTMLCSSJavaScript知识。你将需要一个文本编辑器来编写代码,比如Notepad++、Sublime Text、Visual Studio Code,或者免费AI编程助手豆包 MarsCode

如果你不具备这些基础请移步 ——&前端开发:零基础入门到项目实战

步骤1:创建HTML结构

首先,我们需要创建网页的基本结构。打开你的文本编辑器,输入以下代码:

<!DOCTYPE HTML>
<html>
<head>
    <title>圣诞祝福 - 编程狮(w3cschool.cn)</title>
    <meta charset="utf-8">
</head>
<body>
    <div class="app">
        <!-- 圣诞树将在这里 -->
    </div>
    <div class="message">圣诞快乐!</div> <!-- 消息文本 -->
</body>
</html>

这段代码定义了网页的标题、字符集和基本的HTML结构。

步骤2:添加CSS样式

接下来,我们将添加CSS来设计网页的外观。在<head>标签内添加<style>标签,并输入以下代码:

/* 设置整个页面的基本样式 */
html, body {
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    background: #000;
    overflow: hidden;
    position: relative;
}


/* 应用程序容器的样式 */
.app {
    text-align: center;
    margin: 10px;
}


/* 圣诞树的样式 */
.christmas-tree {
    position: absolute;
    width: 200px;
    height: 300px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


/* 圣诞树枝干的通用样式 */
.christmas-tree .branch {
    position: absolute;
    background-color: #008000;
    border-radius: 50% 50% 0 0;
}


/* 圣诞树树干的样式 */
.christmas-tree .trunk {
    width: 40px;
    height: 80px;
    background-color: #8B4513;
    position: absolute;
    bottom: 0;
    left: 80px;
    border-radius: 5px;
}


/* 圣诞树星星的样式 */
.christmas-tree .star {
    position: absolute;
    top: -20px;
    left: 80px;
    width: 40px;
    height: 40px;
    background-color: gold;
    clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);
    animation: star-twinkle 2s infinite alternate;
}


/* 圣诞树装饰物的样式 */
.christmas-tree .ornament {
    position: absolute;
    width: 20px;
    height: 20px;
    background-color: red;
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(255, 0, 0, 0.5);
    animation: ornament-twinkle 2s infinite alternate;
}


/* 消息文本的样式 */
.message {
    position: absolute;
    top: 40%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    font-size: 48px;
    font-family: Arial, sans-serif;
    text-shadow: 0 0 10px white;
    animation: fadeInOut 4s infinite;
}


/* 雪花效果 */
.snowflake {
    position: absolute;
    width: 10px;
    height: 10px;
    background-color: white;
    border-radius: 50%;
    opacity: 0.8;
    animation: fall linear infinite;
}


/* 动画 */
@keyframes star-twinkle {
    0% { transform: scale(1); }
    100% { transform: scale(1.2); }
}


@keyframes ornament-twinkle {
    0% { transform: scale(1); }
    100% { transform: scale(1.2); }
}


@keyframes fall {
    0% { top: -10px; opacity: 0.8; }
    100% { top: 100vh; opacity: 0; }
}


@keyframes fadeInOut {
    0%, 100% { opacity: 0; }
    50% { opacity: 1; }
}

这段代码定义了网页的所有视觉元素,包括圣诞树、装饰物、星星、雪花和消息文本的样式。

步骤3:构建圣诞树

<div class="app">内添加圣诞树的结构:

<div class="christmas-tree">
    <div class="branch top"></div> <!-- 顶部枝干 -->
    <div class="branch middle"></div> <!-- 中部枝干 -->
    <div class="branch bottom"></div> <!-- 底部枝干 -->
    <div class="trunk"></div> <!-- 树干 -->
    <div class="star"></div> <!-- 星星 -->
    <div class="ornament" style="top: 60px; left: 60px;"></div> <!-- 装饰物1 -->
    <div class="ornament" style="top: 100px; left: 140px;"></div> <!-- 装饰物2 -->
    <div class="ornament" style="top: 140px; left: 100px;"></div> <!-- 装饰物3 -->
    <div class="ornament" style="top: 180px; left: 180px;"></div> <!-- 装饰物4 -->
    <div class="ornament" style="top: 220px; left: 20px;"></div> <!-- 装饰物5 -->
</div>

这段代码定义了圣诞树的各个部分,包括枝干、树干、星星和装饰物。

步骤4:添加 JavaScript

最后,我们需要添加一些 JavaScript 代码来创建飘落的雪花效果。在</body>标签之前添加以下代码:

<script>
    // 创建雪花
    function createSnowflakes(num) {
        for (let i = 0; i < num; i++) {
            const snowflake = document.createElement('div'); // 创建一个 div 元素
            snowflake.classList.add('snowflake'); // 添加雪花类
            snowflake.style.left = Math.random() * 100 + 'vw'; // 随机水平位置
            snowflake.style.animationDuration = Math.random() * 2 + 3 + 's'; // 随机动画持续时间
            document.body.appendChild(snowflake); // 将雪花添加到页面
        }
    }


    // 调用函数创建雪花
    createSnowflakes(100);
</script>

这段代码将创建100个雪花,并随机分布在页面上,模拟雪花飘落的效果。

完成

现在,你已经完成了圣诞祝福网页的制作。将你的代码保存为.html文件,然后用浏览器打开它,你就可以看到一个充满节日气氛的圣诞树和飘落的雪花了。你可以根据自己的喜好调整样式和动画,创造一个独一无二的圣诞祝福网页。祝你编程愉快!

最后附上完整代码:

<!DOCTYPE HTML>
<html>


<head>
    <title>圣诞祝福 - 编程狮(w3cschool.cn)</title>
    <meta charset="utf-8">
    <style>
        /* 设置整个页面的基本样式 */
        html,
        body {
            width: 100%;
            height: 100%;
            margin: 0;
            padding: 0;
            border: 0;
            background: #000; /* 黑色背景 */
            overflow: hidden; /* 隐藏溢出内容 */
            position: relative; /* 使子元素可以相对于此元素定位 */
        }


        /* 应用程序容器的样式 */
        .app {
            text-align: center; /* 文本居中对齐 */
            margin: 10px; /* 外边距 */
        }


        /* 圣诞树的样式 */
        .christmas-tree {
            position: absolute; /* 绝对定位 */
            margin: 0; /* 没有外边距 */
            width: 200px; /* 宽度 */
            height: 300px; /* 高度 */
            top: 50%; /* 垂直居中 */
            left: 50%; /* 水平居中 */
            transform: translate(-50%, -50%); /* 精确居中 */
        }


        /* 圣诞树枝干的通用样式 */
        .christmas-tree .branch {
            position: absolute; /* 绝对定位 */
            background-color: #008000; /* 绿色背景 */
            border-radius: 50% 50% 0 0; /* 上半部分圆角 */
        }


        /* 顶部枝干的样式 */
        .christmas-tree .branch.top {
            width: 160px; /* 宽度 */
            height: 100px; /* 高度 */
            top: 0; /* 从顶部开始 */
            left: 20px; /* 从左边偏移 */
        }


        /* 中部枝干的样式 */
        .christmas-tree .branch.middle {
            width: 200px; /* 宽度 */
            height: 120px; /* 高度 */
            top: 100px; /* 从顶部偏移 */
            left: 0; /* 从左边开始 */
        }


        /* 底部枝干的样式 */
        .christmas-tree .branch.bottom {
            width: 240px; /* 宽度 */
            height: 140px; /* 高度 */
            top: 220px; /* 从顶部偏移 */
            left: -20px; /* 从左边偏移 */
        }


        /* 圣诞树树干的样式 */
        .christmas-tree .trunk {
            width: 40px; /* 宽度 */
            height: 80px; /* 高度 */
            background-color: #8B4513; /* 棕色背景 */
            position: absolute; /* 绝对定位 */
            bottom: 0; /* 从底部开始 */
            left: 80px; /* 从左边偏移 */
            border-radius: 5px; /* 圆角 */
        }


        /* 圣诞树星星的样式 */
        .christmas-tree .star {
            position: absolute; /* 绝对定位 */
            top: -20px; /* 从顶部偏移 */
            left: 80px; /* 从左边偏移 */
            width: 40px; /* 宽度 */
            height: 40px; /* 高度 */
            background-color: gold; /* 金色背景 */
            clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%); /* 星星形状 */
            animation: star-twinkle 2s infinite alternate; /* 闪烁动画 */
        }


        /* 圣诞树装饰物的样式 */
        .christmas-tree .ornament {
            position: absolute; /* 绝对定位 */
            width: 20px; /* 宽度 */
            height: 20px; /* 高度 */
            background-color: red; /* 红色背景 */
            border-radius: 50%; /* 圆形 */
            box-shadow: 0 0 10px rgba(255, 0, 0, 0.5); /* 发光效果 */
            animation: ornament-twinkle 2s infinite alternate; /* 闪烁动画 */
        }


        /* 星星闪烁动画 */
        @keyframes star-twinkle {
            0% {
                transform: scale(1); /* 初始大小 */
            }
            100% {
                transform: scale(1.2); /* 放大 */
            }
        }


        /* 装饰物闪烁动画 */
        @keyframes ornament-twinkle {
            0% {
                transform: scale(1); /* 初始大小 */
            }
            100% {
                transform: scale(1.2); /* 放大 */
            }
        }


        /* 雪花效果 */
        .snowflake {
            position: absolute; /* 绝对定位 */
            width: 10px; /* 宽度 */
            height: 10px; /* 高度 */
            background-color: white; /* 白色背景 */
            border-radius: 50%; /* 圆形 */
            opacity: 0.8; /* 透明度 */
            animation: fall linear infinite; /* 下落动画 */
        }


        /* 雪花下落动画 */
        @keyframes fall {
            0% {
                top: -10px; /* 从顶部开始 */
                opacity: 0.8; /* 透明度 */
            }
            100% {
                top: 100vh; /* 下落到屏幕底部 */
                opacity: 0; /* 透明度逐渐消失 */
            }
        }


        /* 消息文本的样式 */
        .message {
            position: absolute; /* 绝对定位 */
            top: 40%; /* 从顶部偏移 */
            left: 50%; /* 从左边偏移 */
            transform: translate(-50%, -50%); /* 精确居中 */
            color: white; /* 白色文字 */
            font-size: 48px; /* 字体大小 */
            font-family: Arial, sans-serif; /* 字体 */
            text-shadow: 0 0 10px white; /* 发光效果 */
            animation: fadeInOut 4s infinite; /* 渐隐渐现动画 */
        }


        /* 消息文本渐隐渐现动画 */
        @keyframes fadeInOut {
            0%, 100% {
                opacity: 0; /* 完全透明 */
            }
            50% {
                opacity: 1; /* 完全不透明 */
            }
        }
    </style>
</head>


<body>
    <div class="app">
        <div class="christmas-tree">
            <div class="branch top"></div> <!-- 顶部枝干 -->
            <div class="branch middle"></div> <!-- 中部枝干 -->
            <div class="branch bottom"></div> <!-- 底部枝干 -->
            <div class="trunk"></div> <!-- 树干 -->
            <div class="star"></div> <!-- 星星 -->
            <div class="ornament" style="top: 60px; left: 60px;"></div> <!-- 装饰物1 -->
            <div class="ornament" style="top: 100px; left: 140px;"></div> <!-- 装饰物2 -->
            <div class="ornament" style="top: 140px; left: 100px;"></div> <!-- 装饰物3 -->
            <div class="ornament" style="top: 180px; left: 180px;"></div> <!-- 装饰物4 -->
            <div class="ornament" style="top: 220px; left: 20px;"></div> <!-- 装饰物5 -->
        </div>
    </div>


    <div class="message">圣诞快乐!</div> <!-- 消息文本 -->


    <script>
        // 创建雪花
        function createSnowflakes(num) {
            for (let i = 0; i < num; i++) {
                const snowflake = document.createElement('div'); // 创建一个 div 元素
                snowflake.classList.add('snowflake'); // 添加雪花类
                snowflake.style.left = Math.random() * 100 + 'vw'; // 随机水平位置
                snowflake.style.animationDuration = Math.random() * 2 + 3 + 's'; // 随机动画持续时间
                document.body.appendChild(snowflake); // 将雪花添加到页面
            }
        }


        // 调用函数创建雪花
        createSnowflakes(100);
    </script>
</body>


</html>

更多实例分享

4 人点赞