如何用CSS从正方形制作彩虹心动画

来源:建站作者:孙悟空头衔:草根站长
导读:本期聚焦于小伙伴创作的《如何用CSS从正方形制作彩虹心动画》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《如何用CSS从正方形制作彩虹心动画》有用,将其分享出去将是对创作者最好的鼓励。

用CSS从正方形制作彩虹心动画,核心思路是先通过两个正方形的旋转和定位拼接出心形的基础轮廓,再结合渐变背景和关键帧动画实现彩虹色的动态效果,整个过程不需要引入任何外部图片资源。

如何用CSS从正方形制作彩虹心动画

实现原理拆解

心形的基础结构可以由两个旋转了45度的正方形组合而成,两个正方形的顶部边缘对接,就能形成心形的上半部分两个圆弧和下半部分的尖角。彩虹效果则可以通过线性渐变背景配合动画改变背景位置来实现,让颜色呈现出流动的效果。

基础HTML结构

只需要一个容器元素和两个子元素来作为两个正方形即可:

<div class="heart-container">
  <div class="heart-square left"></div>
  <div class="heart-square right"></div>
</div>

CSS样式编写

首先设置容器和正方形的基础样式,这里先给正方形添加渐变背景,为后续的彩虹效果做准备:

/* 容器样式,用于居中显示 */
.heart-container {
  position: relative;
  width: 200px;
  height: 180px;
  margin: 50px auto;
}

/* 正方形基础样式 */
.heart-square {
  position: absolute;
  width: 100px;
  height: 100px;
  /* 彩虹渐变背景 */
  background: linear-gradient(45deg, 
    #ff0000, #ff9900, #ffff00, 
    #00ff00, #0099ff, #6600ff
  );
  background-size: 400% 400%;
  border-radius: 10px;
}

/* 左侧正方形,向右旋转45度 */
.heart-square.left {
  top: 0;
  left: 50px;
  transform: rotate(45deg);
  transform-origin: 0 100%;
}

/* 右侧正方形,向左旋转45度 */
.heart-square.right {
  top: 0;
  right: 50px;
  transform: rotate(-45deg);
  transform-origin: 100% 100%;
}

添加彩虹流动动画

通过@keyframes定义背景位置的变化,让渐变的颜色不断流动,形成彩虹动态效果:

/* 定义彩虹流动动画 */
@keyframes rainbow_flow {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}

/* 给两个正方形应用动画 */
.heart-square {
  animation: rainbow_flow 3s ease infinite;
}

优化细节

如果希望心形的边缘更圆润,可以给两个正方形添加更大的border-radius,同时调整定位让拼接更自然:

.heart-square {
  width: 110px;
  height: 110px;
  border-radius: 20px;
}

.heart-square.left {
  left: 45px;
}

.heart-square.right {
  right: 45px;
}

完整运行代码

将以下代码保存为HTML文件,直接在浏览器中打开就能看到彩虹心动画效果:

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>CSS彩虹心动画</title>
  <style>
    .heart-container {
      position: relative;
      width: 200px;
      height: 180px;
      margin: 50px auto;
    }

    .heart-square {
      position: absolute;
      width: 110px;
      height: 110px;
      background: linear-gradient(45deg, 
        #ff0000, #ff9900, #ffff00, 
        #00ff00, #0099ff, #6600ff
      );
      background-size: 400% 400%;
      border-radius: 20px;
      animation: rainbow_flow 3s ease infinite;
    }

    .heart-square.left {
      top: 0;
      left: 45px;
      transform: rotate(45deg);
      transform-origin: 0 100%;
    }

    .heart-square.right {
      top: 0;
      right: 45px;
      transform: rotate(-45deg);
      transform-origin: 100% 100%;
    }

    @keyframes rainbow_flow {
      0% {
        background-position: 0% 50%;
      }
      50% {
        background-position: 100% 50%;
      }
      100% {
        background-position: 0% 50%;
      }
    }
  </style>
</head>
<body>
  <div class="heart-container">
    <div class="heart-square left"></div>
    <div class="heart-square right"></div>
  </div>
</body>
</html>

注意事项

  • 两个正方形的transform-origin属性必须设置正确,否则旋转后无法拼接成心形轮廓
  • 渐变的background-size要设置比元素本身大,否则动画时颜色变化不明显
  • 如果调整了正方形的尺寸,需要同步调整容器的宽高和两个正方形的定位数值,避免出现拼接错位

CSS彩虹心动画正方形变形keyframestransform修改时间:2026-06-24 12:03:35

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。