15.html+css网页设计实例/“表白”主题介绍/360°环绕旋转生日蛋糕树完整代码/

前言

本文以"表白"为主题设计,应用html+css代码制作。360°环绕旋转效果的蛋糕的完整代码,分享给大家!

关注作者 |获取更多源码(2000+个Web案例源码 )|优质文章】;您的支持是我创作的动力!看到这里就【点赞收藏博文】,三连支持下吧,3Q!


一、网页效果


二、代码展示

完整代码展示如下:

1.HTML

<!DOCTYPE html>

<html lang="en" >

<head>

<meta charset="UTF-8">

<title>Tree</title>

<meta name="viewport" content="width=device-width, initial-scale=1">

<link rel="stylesheet" href="css/style.css">

</head>

<body>

<main>

<ul class="star" style="--v: 1; --t: 1;">

<li style="--i: 0"></li>

</ul>

<ul style="--v: 2; --t: 8; --direction:reverse">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

</ul>

<ul style="--v: 3; --t: 12">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

</ul>

<ul style="--v: 4; --t: 18; --direction:reverse">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

<li style="--i: 12"></li>

<li style="--i: 13"></li>

<li style="--i: 14"></li>

<li style="--i: 15"></li>

<li style="--i: 16"></li>

<li style="--i: 17"></li>

</ul>

<ul style="--v: 5; --t: 22">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

<li style="--i: 12"></li>

<li style="--i: 13"></li>

<li style="--i: 14"></li>

<li style="--i: 15"></li>

<li style="--i: 16"></li>

<li style="--i: 17"></li>

<li style="--i: 18"></li>

<li style="--i: 19"></li>

<li style="--i: 20"></li>

<li style="--i: 21"></li>

</ul>

<ul style="--v: 6; --t: 26; --direction:reverse">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

<li style="--i: 12"></li>

<li style="--i: 13"></li>

<li style="--i: 14"></li>

<li style="--i: 15"></li>

<li style="--i: 16"></li>

<li style="--i: 17"></li>

<li style="--i: 18"></li>

<li style="--i: 19"></li>

<li style="--i: 20"></li>

<li style="--i: 21"></li>

<li style="--i: 22"></li>

<li style="--i: 23"></li>

<li style="--i: 24"></li>

<li style="--i: 25"></li>

</ul>

<ul style="--v: 7; --t: 32">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

<li style="--i: 12"></li>

<li style="--i: 13"></li>

<li style="--i: 14"></li>

<li style="--i: 15"></li>

<li style="--i: 16"></li>

<li style="--i: 17"></li>

<li style="--i: 18"></li>

<li style="--i: 19"></li>

<li style="--i: 20"></li>

<li style="--i: 21"></li>

<li style="--i: 22"></li>

<li style="--i: 23"></li>

<li style="--i: 24"></li>

<li style="--i: 25"></li>

<li style="--i: 26"></li>

<li style="--i: 27"></li>

<li style="--i: 28"></li>

<li style="--i: 29"></li>

<li style="--i: 30"></li>

<li style="--i: 31"></li>

</ul>

<ul style="--v: 8; --t: 36; --direction:reverse">

<li style="--i: 0"></li>

<li style="--i: 1"></li>

<li style="--i: 2"></li>

<li style="--i: 3"></li>

<li style="--i: 4"></li>

<li style="--i: 5"></li>

<li style="--i: 6"></li>

<li style="--i: 7"></li>

<li style="--i: 8"></li>

<li style="--i: 9"></li>

<li style="--i: 10"></li>

<li style="--i: 11"></li>

<li style="--i: 12"></li>

<li style="--i: 13"></li>

<li style="--i: 14"></li>

<li style="--i: 15"></li>

<li style="--i: 16"></li>

<li style="--i: 17"></li>

<li style="--i: 18"></li>

<li style="--i: 19"></li>

<li style="--i: 20"></li>

<li style="--i: 21"></li>

<li style="--i: 22"></li>

<li style="--i: 23"></li>

<li style="--i: 24"></li>

<li style="--i: 25"></li>

<li style="--i: 26"></li>

<li style="--i: 27"></li>

<li style="--i: 28"></li>

<li style="--i: 29"></li>

<li style="--i: 30"></li>

<li style="--i: 31"></li>

<li style="--i: 32"></li>

<li style="--i: 33"></li>

<li style="--i: 34"></li>

<li style="--i: 35"></li>

</ul>

</main>

</body>

</html>

2.CSS

:root {

--unit: 1.6vmin;

--width: calc(var(--unit) * 6);

--height: calc(var(--unit) * 8);

}

ul, li {

position: absolute;

width: var(--width);

height: var(--height);

top: 50%;

left: 50%;

transform: translate(-50%, -50%) var(--transform, translate(0,0));

transform-style: preserve-3d;

z-index: -1;

}

li {

background: hsl(calc(var(--i) * 360 / var(--t)), 100%, 53%);

background: radial-gradient(circle, hsl(216, 88%, 86%) 22%, hsl(216, 88%, 26%) 22%) top center;

background-size: calc(var(--unit) * 1.5) calc(var(--unit) * 1.5);

--clip-path: polygon(0% 100%, 50% 0%, 100% 100%);

--transform: rotateY(calc(var(--i) * calc(360deg / var(--t)))) translateZ(calc(var(--width) * .09 * var(--t))) rotateX(0deg);

transform-origin: 50% 100%;

-webkit-clip-path: var(--clip-path);

clip-path: var(--clip-path);

}

li:nth-of-type(even) {

--clip-path: polygon(0% 0%, 50% 100%, 100% 0%);

}

li:nth-of-type(6n + 2) {

background: linear-gradient(to right, hsl(343, 88%, 56%) 50%, hsl(343, 88%, 36%) 50%);

}

li:nth-of-type(6n + 3) {

background-image: linear-gradient(to bottom, hsl(143, 70%, 18%) 0vmin, hsl(143, 70%, 18%) 1.8vmin, hsl(143, 70%, 78%) 1.8vmin, hsl(143, 70%, 78%) 2vmin);

}

li:nth-of-type(6n + 4) {

background:

repeating-linear-gradient(135deg, hsla(347, 88%, 76%, 0) 0, hsla(347, 88%, 76%, 0) calc(var(--unit) * .75), hsl(223, 88%, 46%) calc(var(--unit) * .75), hsl(223, 88%, 46%) calc(var(--unit) * 1.5)),

repeating-linear-gradient(45deg, hsl(347, 88%, 46%) 0, hsl(347, 88%, 46%) var(--unit), hsl(143, 38%, 36%) var(--unit), hsl(143, 38%, 36%) calc(var(--unit) * 1.5));

background-size: contain;

}

li:nth-of-type(6n + 5) {

background: linear-gradient(to right, hsl(43, 88%, 36%) 50%, hsl(43, 88%, 56%) 50%);

}

li:nth-of-type(6n + 6) {

--color: hsl(243, 8%, 86%);

--alt: hsl(342, 88%, 46%);

background: linear-gradient(to right, var(--color) 50%, hsl(243, 8%, 66%) 50%);

}

@supports ( background-image: repeating-conic-gradient(at 50% 36%, red 30deg, red 45deg, green 45deg, green 60deg)) {

li:nth-of-type(6n + 6) {

background-image:

repeating-conic-gradient(at 50% 36%,

var(--color) 30deg,

var(--color) 45deg,

var(--alt) 45deg,

var(--alt) 60deg);

}

}

ul {

top: 8vmin;

animation: display-case calc(var(--t) * 1000ms) infinite linear;

animation-direction: var(--direction, normal);

animation-delay: -10000ms;

}

.star {

animation-duration: calc(var(--t) * 4000ms);

}

.star li {

--clip-path: polygon(50% 0%, 61% 35%, 98% 35%, 68% 57%, 79% 91%, 50% 70%, 21% 91%, 32% 57%, 2% 35%, 39% 35%);

--transform: translateY(-4vmin);

background: linear-gradient(to right, hsl(43, 88%, 36%) 50%, hsl(43, 88%, 56%) 50%);

}

@keyframes display-case {

0% {

transform: translate(-50%, -100%) rotateY(0deg) translateY(calc(var(--v, 0) * 6 * var(--unit)));

}

100% {

transform: translate(-50%, -100%) rotateY(360deg) translateY(calc(var(--v, 0) * 6 * var(--unit)));

}

}

@keyframes topsy-turvy {

0% {

transform: translate(-50%, -100%) rotateY(0deg) translateY(calc(var(--v, 0) * 6 * var(--unit))) rotateZ(-5deg);

}

50% {

transform: translate(-50%, -100%) rotateY(180deg) translateY(calc(var(--v, 0) * 6 * var(--unit))) rotateZ(5deg);

}

100% {

transform: translate(-50%, -100%) rotateY(360deg) translateY(calc(var(--v, 0) * 6 * var(--unit))) rotateZ(-5deg);

}

}

main {

width: 100vmin;

height: 100vmin;

transform-style: preserve-3d;

}

body {

min-height: 100vh;

display: flex;

justify-content: center;

align-items: center;

overflow: hidden;

perspective: 120vmin;

background: hsl(216, 80%, 12%);

background-image: radial-gradient(circle at 50% 55%, hsl(216, 80%, 32%), hsl(216, 80%, 22%) 24vmin, hsl(216, 80%, 12%) 44vmin);

}

*, *::before, *::after {

box-sizing: border-box;

margin: 0;

padding: 0;

}

相关推荐
B站计算机毕业设计超人18 分钟前
计算机毕业设计PySpark+Hadoop中国城市交通分析与预测 Python交通预测 Python交通可视化 客流量预测 交通大数据 机器学习 深度学习
大数据·人工智能·爬虫·python·机器学习·课程设计·数据可视化
吃杠碰小鸡31 分钟前
lodash常用函数
前端·javascript
emoji11111141 分钟前
前端对页面数据进行缓存
开发语言·前端·javascript
泰伦闲鱼44 分钟前
nestjs:GET REQUEST 缓存问题
服务器·前端·缓存·node.js·nestjs
m0_748250031 小时前
Web 第一次作业 初探html 使用VSCode工具开发
前端·html
一个处女座的程序猿O(∩_∩)O1 小时前
vue3 如何使用 mounted
前端·javascript·vue.js
m0_748235951 小时前
web复习(三)
前端
机器视觉李小白1 小时前
使用 HTML 和 CSS 实现绚丽的节日烟花效果
css·html·烟花·节日·节日祝福
AiFlutter1 小时前
Flutter-底部分享弹窗(showModalBottomSheet)
java·前端·flutter
麦兜*1 小时前
轮播图带详情插件、uniApp插件
前端·javascript·uni-app·vue