前端每日实战:6# 视频演示如何用纯 CSS 绘制一颗闪闪发光的璀璨钻石

图片描述

效果预览

按下右侧的“点击预览”按钮在当前页面预览,点击连接全屏预览。css

https://codepen.io/zhang-ou/pen/qYqwQphtml

可交互视频教程

此视频是能够交互的,你能够随时暂停视频,编辑视频中的代码。git

请用 chrome, safari, edge 打开观看。github

https://scrimba.com/c/cp24VfVchrome

源代码下载

请从 github 下载。dom

https://github.com/comehope/front-end-daily-challenges/tree/master/006-blue-dazzling-diamondflex

代码解读

定义 dom,容器中包含一个元素:动画

<div class="diamond">
    <span></span>
</div>

居中显示:spa

html,
body {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}

画出第一组刻面的形状:code

.diamond {
    display: grid;
}

.diamond span {
    border-width: 50px;
    border-style: solid;
}

为第一组刻面上色,由于后面还要用到这些色值,因此定义了变量:

:root {
    --color1: deepskyblue;
    --color2: steelblue;
    --color3: royalblue;
    --color4: dodgerblue;
}

.diamond span {
    border-color: var(--color1) var(--color2) var(--color3) var(--color4);
}

dom容器 中再增长3组刻面:

<div class="diamond">
    <span></span>
    <span></span>
    <span></span>
    <span></span>
</div>

把4组刻面先组成田字格,再转换成钻石形状:

.diamond {
    grid-template-columns: 1fr 1fr;
    transform: rotate(45deg);
}

.diamond span:first-child {
    border-color: transparent var(--color2) var(--color3) transparent;
}

定义动画效果:

@keyframes animate {
    0% {
        border-color: var(--color1) var(--color2) var(--color3) var(--color4);
    }
    
    25% {
        border-color: var(--color4) var(--color1) var(--color2) var(--color3);
    }
    
    50% {
        border-color: var(--color3) var(--color4) var(--color1) var(--color2);
    }
    
    75% {
        border-color: var(--color2) var(--color3) var(--color4) var(--color1);
    }
    
    100% {
        border-color: var(--color1) var(--color2) var(--color3) var(--color4);
    }
}

最后,把动画效果应用到除第1组之外的刻面上:

.diamond span:not(:first-child) {
    animation: animate 2s linear infinite;
}

大功告成!

知识点

相关文章
相关标签/搜索