分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 教程案例

如何用纯 CSS 创作一根闪电连接线

发布时间:2023-09-06 02:25责任编辑:傅花花关键词:CSS

效果预览

在线演示

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


https://codepen.io/comehope/pen/RBjdzZ


可交互视频


此视频是可以交互的,你可以随时暂停视频,编辑视频中的代码。


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


https://scrimba.com/p/pEgDAM/cgkE6C6


源代码下载


本地下载

每日前端实战系列的全部源代码请从 github 下载:


https://github.com/comehope/front-end-daily-challenges


代码解读


定义 dom,容器中包含 2 个元素,分别代表插头和线缆:

<div class="cable"> ???<span class="head"></span> ???<span class="body"></span></div>

居中显示:

body { ???margin: 0; ???height: 100vh; ???display: flex; ???align-items: center;}

定义容器尺寸:

.cable { ???display: flex; ???align-items: center; ???font-size: 10px; ???margin-left: 5em;}

画出插头的轮廓:

.head { ???width: 8.5em; ???height: 8.5em; ???border-radius: 2em 0 0 2em;}

画出插头上针脚的轮廓:

.head { ???position: relative;}.head::before { ???content: ''; ???position: absolute; ???width: 3em; ???height: 7.3em; ???top: calc((8.5em - 7.3em) / 2); ???left: 0.7em; ???border-radius: 1em; ???box-sizing: border-box;}

画出线缆中手持部位的轮廓:

.body { ???width: 15.5em; ???height: 11em; ???border-radius: 0.5em;}

画出线缆中稍粗部位的轮廓:

.body { ???position: relative; ???display: flex; ???align-items: center;}.body::before { ???content: ''; ???position: absolute; ???width: 13.5em; ???height: 6em; ???left: 15.5em;}

画出线缆的延长线部分:

.body::after { ???content: ''; ???position: absolute; ???width: 100vh; ???height: 3.9em; ???left: calc(15.5em + 13.5em);}

隐藏画面外的部分:

body { ???overflow: hidden;}

接下来绘制细节。
为延长线涂上渐变色:

.body::after { ???background: ???????linear-gradient( ???????????white, ???????????hsl(0, 0%, 96%) 5%, ?????????????hsl(0, 0%, 97%) 25%, ????????????hsl(0, 0%, 95%) 40%, ????????????hsl(0, 0%, 81%) 95%, ???????????white ???????);}

为线缆中稍粗部位涂上渐变色:

.body::before { ???background: ???????linear-gradient( ???????????white, ???????????hsl(0, 0%, 96%) 5%, ?????????????hsl(0, 0%, 98%) 20%, ????????????hsl(0, 0%, 95%) 50%, ????????????hsl(0, 0%, 81%) 95%, ???????????white ???????);}

为线缆中手持部位涂上渐变色:

.body { ???background:linear-gradient( ???????hsl(0, 0%, 91%), ???????white 15%, ????????hsl(0, 0%, 93%) 50%, ????????hsl(0, 0%, 87%) 70%, ???????hsl(0, 0%, 79%) 90%, ???????hsl(0, 0%, 84%), ????????hsl(0, 0%, 86%) ???);}

为插头涂上渐变色:

.head { ???background: ???????linear-gradient( ???????????-45deg, ????????????hsl(0, 0%, 75%), ???????????hsl(0, 0%, 79%), ???????????hsl(0, 0%, 78%), ???????????hsl(0, 0%, 87%) 80% ???????);}

在插头上画出针脚:

.head::before { ???background-color: white;}.head::after { ???content: ''; ???position: absolute; ???box-sizing: border-box; ???width: 2.2em; ???height: 0.4em; ???color: goldenrod; ???background-color: currentColor; ???border-radius: 0.5em; ???left: 1.1em; ???top: 1.2em; ???box-shadow: ????????0 0.8em 0, ???????0 1.6em 0, ???????0 2.4em 0, ???????0 3.2em 0, ???????0 4em 0, ???????0 4.8em 0, ???????0 5.6em 0;}

接下来添加阴影,使线缆更立体。
绘制插头上的阴影:

.head { ???background: ???????linear-gradient( ???????????90deg, ????????????transparent 80%, ???????????rgba(0,0,0,12%) ???????), ???????linear-gradient( ???????????-45deg, ????????????hsl(0, 0%, 75%), ???????????hsl(0, 0%, 79%), ???????????hsl(0, 0%, 78%), ???????????hsl(0, 0%, 87%) 80% ???????);}

绘制线缆手持部分的阴影:

.body::before { ???background: ???????linear-gradient( ???????????45deg, ????????????rgba(0,0,0,4%) 10%, ???????????transparent 20% ???????), ???????????linear-gradient( ???????????90deg, ????????????rgba(0,0,0,4%), ????????????transparent 10% ???????), ???????linear-gradient( ???????????white, ???????????hsl(0, 0%, 96%) 5%, ?????????????hsl(0, 0%, 98%) 20%, ????????????hsl(0, 0%, 95%) 50%, ????????????hsl(0, 0%, 81%) 95%, ???????????white ???????);}

绘制线缆中稍粗部位的阴影:

.body::after { ???background: ???????linear-gradient( ???????????45deg, ????????????rgba(0,0,0,4%), ???????????transparent 4% ???????), ???????linear-gradient( ???????????90deg, ????????????rgba(0,0,0,4%), ???????????transparent 2% ???????), ???????linear-gradient( ???????????white, ???????????hsl(0, 0%, 96%) 5%, ?????????????hsl(0, 0%, 97%) 25%, ????????????hsl(0, 0%, 95%) 40%, ????????????hsl(0, 0%, 81%) 95%, ???????????white ???????);}

最后,为画面增加入场动画

.cable { ???animation: show 5s linear infinite;}@keyframes show { ???0% { ???????transform: translateX(100vw); ???} ???20%, 100% { ???????transform: translateX(0); ???}}

大功告成!

原文地址:https://segmentfault.com/a/1190000015809333

如何用纯 CSS 创作一根闪电连接线

原文地址:https://www.cnblogs.com/lalalagq/p/10078085.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved