百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

用css3实现惊艳面试官的背景即背景动画(高级附源码)

toyiye 2024-07-08 22:58 11 浏览 0 评论

我们传统的前端更多的是用javascript实现各种复杂动画,自从有了Css3 transition和animation以来,前端开发在动画这一块有了更高的自由度和格局,对动画的开发也越来越容易。这篇文章就让我们汇总一下使用Css3实现的各种特效。这篇文章参考《css揭秘》这本书,并作出了自己的总结,希望能让大家更有收获,也强烈推荐大家看看这本书,你值得拥有。

我们将学到

  • Css3
  • outline
  • radial-gradient
  • linear-gradient
  • box-shadow

1.实现内部虚线边框

知识点:outline

核心代码.dash-border{
 width: 200px;
 height: 100px;
 line-height: 100px;
 outline: 1px dashed #fff;
 outline-offset: -10px;
}
复制代码

2.边框内圆角的实现

知识点:box-shadow

核心代码.radius-border{
 margin-top: 20px;
 width: 180px;
 height: 80px;
 box-shadow: 0 0 0 10px gray;
}
复制代码

3.实现条纹背景与进度条

知识点:linear-gradient,repeating-linear-gradient

核心代码/* 上 */
background: linear-gradient(to right,#fb3 50%,#58a 0);
background-size: 40px 100%;
box-shadow: inset 0 0 3px #555;
/* 中 */
background: linear-gradient(45deg,#fb3 25%,#58a 0,#58a 50%,#fb3 0,#fb3 75%,#58a 0);
background-size: 40px 40px;
/* 下 (可以实现任意角度的渐变,45°时显示效果最好) */
background: repeating-linear-gradient(60deg,#fb3,#fb3 15px,#58a 0,#58a 30px);
复制代码

4.复杂的背景图案

知识点:linear-gradient,repeating-linear-gradient,radial-gradient

由于第二个图会有复杂的随机动画,建议大家可以亲自尝试看看效果,核心代码

<style>
.bg-grid{
 margin-top: 20px;
 width: 200px;
 height: 200px;
 background-image: linear-gradient(rgba(255,255,255,1) 2px,transparent 0),
 linear-gradient(to right,rgba(255,255,255,1) 2px,transparent 0),
 linear-gradient(rgba(255,255,255,.2) 1px,transparent 0),
 linear-gradient(to right,rgba(255,255,255,.2) 1px,transparent 0);
 background-position: -50px -50px;
 background-size: 100px 100px,100px 100px, 100% 10px, 10px 100%;
}
.animate-grid{
 animation: move-grid 6s linear infinite;
}
@keyframes move-grid{
 0%{
 background-position: -50px -50px;
 }
 30%{
 background-position: -100px -100px;
 }
 60%{
 background-position: -100px -150px;
 }
 100%{
 background-position: -50px -50px;
 }
}
</style>
<div class="bg-grid black-theme"></div>
<div class="bg-grid black-theme animate-grid"></div>
复制代码

红绿灯以及红路灯随机运动动画

利用css3多背景和position实现红绿灯和背景色块移动核心代码

<style>
.bg-dot{
 margin-top: 20px;
 width: 200px;
 height: 50px;
 background-image: radial-gradient(circle,#0cf 15px,transparent),
 radial-gradient(circle,red 15px,transparent),
 radial-gradient(circle,yellow 15px,transparent),
 radial-gradient(circle,green 15px,transparent);
 background-repeat: no-repeat;
 background-position: 0 0, 50px 0, 100px 0, 150px 0, 200px 0;
 background-size: 50px 50px;
}
.animate-dot{
 animation: move-dot 8s linear infinite;
}
.animate-dot2{
 animation: move-dot2 6s linear infinite;
}
@keyframes move-dot{
 0%{
 background-position: 0 0, 50px 0, 100px 0, 150px 0;
 }
 30%{
 background-position: 50px 0, 0 0, 100px 0, 150px 0;
 }
 60%{
 background-position: 50px 0, 100px 0, 0 0, 150px 0;
 }
 100%{
 background-position: 50px 0, 100px 0, 150px 0, 0 0;
 }
}
@keyframes move-dot2{
 0%{
 background-image: radial-gradient(circle,#0cf 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent);
 }
 30%{
 background-image: radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,red 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent);
 }
 60%{
 background-image: radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,yellow 15px,transparent),
 radial-gradient(circle,gray 15px,transparent);
 }
 100%{
 background-image: radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,gray 15px,transparent),
 radial-gradient(circle,green 15px,transparent);
 }
}
</style>
<div class="bg-dot black-theme animate-dot"></div>
<div class="bg-dot black-theme animate-dot2"></div>
复制代码

棋盘背景以及棋盘背景随机动画

利用背景渐变实现棋盘图案核心代码

<style>
.bg-qi{
 margin-top: 20px;
 width: 200px;
 height: 200px;
 background-color: #eee;
 background-image: linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0),
 linear-gradient(45deg,rgba(0,0,0,.25) 25%,transparent 0,transparent 75%,rgba(0,0,0,.25) 0);
 background-position: 0 0, 20px 20px;
 background-size: 40px 40px;
 box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
</style>
<div class="bg-qi black-theme"></div>
复制代码

伪随机背景

利用背景渐变,keyframe动画,实现复杂的伪随机动画核心代码

<style>
.bg-line-rand{
 margin-top: 20px;
 width: 480px;
 height: 60px;
 background-color: #eee;
 background-image: linear-gradient(90deg,#fb3 11px, transparent 0),
 linear-gradient(90deg,#ab4 23px, transparent 0),
 linear-gradient(90deg,#655 41px, transparent 0);
 background-size: 41px 100%, 61px 100%, 83px 100%;
 box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
.bg-dot-rand{
 margin-top: 20px;
 width: 200px;
 height: 200px;
 background-color: #eee;
 background-image: radial-gradient(circle,#fb3 5px, transparent 0),
 radial-gradient(circle,#ab4 13px, transparent 0),
 radial-gradient(circle,#655 31px, transparent 0);
 background-repeat: no-repeat;
 background-size: 101px 203px, 147px 60px, 373px 201px;
 box-shadow: 2px 2px 4px rgba(0,0,0,.4);
}
.animate1{
 animation: move 4s linear infinite;
}
.animate2{
 animation: move2 4s linear infinite;
}
@keyframes move{
 0%{
 background-position: 0 0, 0 0, 0 0;
 }
 50%{
 background-position: -10px 0, 20px 0, 30px 0;
 }
 100%{
 background-position: 0 0, 30px 0, 10px 0;
 }
}
@keyframes move2{
 0%{
 background-position: 0 0, 0 0, 0 0;
 }
 50%{
 background-position: -10px 30px, 20px 0, -40px 80px;
 }
 100%{
 background-position: 0 20px, 60px -20px, 10px 30px;
 }
}
</style>
<div class="bg-line-rand black-theme"></div>
<div class="bg-line-rand black-theme animate1"></div>
<div class="bg-dot-rand black-theme animate2"></div>
复制代码

5.折角效果

知识点:linear-gradient

核心代码

<style>
.fold{
 margin-left: auto;
 margin-right: auto;
 margin-bottom: 20px;
 width: 200px;
 height: 80px;
 color: #fff;
 line-height: 80px;
 text-align: center;
 background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5) 0) no-repeat 100% 0 / 2em 2em,
 linear-gradient(-135deg,transparent 1.4em,#06c 0);
}
.linear{
 background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.5)) no-repeat 100% 0 / 2em 2em,
 linear-gradient(-135deg,transparent 1.4em,#06c);
}
</style>
<div class="fold">折角效果哦</div>
<div class="fold linear">折角效果哦</div>
复制代码

2.内阴影圆折角效果

核心代码

<style>
.fold-1{
 margin-left: auto;
 margin-right: auto;
 margin-bottom: 20px;
 position: relative;
 width: 200px;
 height: 80px;
 border-radius: .5em;
 color: #fff;
 line-height: 80px;
 text-align: center;
 background: linear-gradient(-150deg,transparent 1.5em, #58a 0);
}
.fold-1::before{
 content: "";
 position: absolute;
 top: 0;
 right: 0;
 background: linear-gradient(to left bottom,transparent 50%,rgba(0,0,0,.2) 0,rgba(0,0,0,.4)) 100% 0 no-repeat;
 width: 1.73em;
 height: 3em;
 transform: translateY(-1.3em) rotate(-30deg);
 transform-origin: bottom right;
 border-bottom-left-radius: inherit;
 box-shadow: -.2em .2em .3em -.1em rgba(0,0,0,.15);
}
</style>
<div class="fold-1">折角效果哦</div>
复制代码

6.自适应文本的条纹背景

知识点:linear-gradient,line-height,background-origin

核心代码

<style>
.stripe-bg{
 padding: .5em;
 line-height: 1.5em;
 background: beige;
 background-size: auto 3em;
 background-origin: content-box;
 background-image: linear-gradient(rgba(0,0,0,.2) 50%, transparent 0);
}
.stripe-bg > p{
 margin: 0;
}
</style>
<div class="stripe-bg">
 <p>hello you</p>
 <p>hello you</p>
 <p>hello you</p>
 <p>hello you</p>
 <p>hello you</p>
</div>
复制代码

7.自定义的下划线实现

知识点linear-gridient

小伙伴们注意到了吗?默认的下划线会将文字穿过,而上面的不会呦!

核心代码

<style>
.my-line{
 line-height: 1.4em;
 background: linear-gradient(gray,gray) no-repeat;
 background-size: 100% 1px;
 background-position: 0 1.15em;
 text-shadow: .05em 0 #fff, -.05em 0 #fff;
}
</style>
<div class=""><span class="my-line">i have your big apple.you have a too? hi hi hi.</span></div>
复制代码

最后

笔者3天后将推出开源的CMS系统,技术架构:

  • 后台Node+Koa+redis+JsonSchema
  • 管理后台界面 vue-cli3 + vue + ts + vuex + antd-vue + axios
  • 客户端前台 react + antd + react-hooks + axios

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码