web前端入门到实战:用css3实现惊艳面试官的背景即背景动画(高级附源码)

我们传统的前端更多的是用javascript实现各种复杂动画,自从有了Css3 transition和animation以来,前端开发在动画这一块有了更高的自由度和格局,对动画的开发也越来越容易。这篇文章就让我们汇总一下使用Css3实现的各种特效。

1.实现内部虚线边框
知识点:outline

核心代码

.dash-border{
  width: 200px;
  height: 100px;
  line-height: 100px;
  outline: 1px dashed #fff;
  outline-offset: -10px;
}
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

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>
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

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

利用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>
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

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

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

<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>
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

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: inheri
  box-shadow: -.2em .2em .3em -.1em rgba(0,0,0,.15);
}

</style>
<div class="fold-1">折角效果哦</div>
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

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>
web前端开发学习Q-q-u-n:784783012 ,分享学习的方法和需要注意的小细节,不停更新最新的教程和学习方法(详细的前端项目实战教学视频)

原文地址:https://blog.51cto.com/14592820/2447419

时间: 2024-11-10 01:17:44

web前端入门到实战:用css3实现惊艳面试官的背景即背景动画(高级附源码)的相关文章

web前端入门到实战:css3循环,模拟拼多多动画效果

模拟拼多多动画效果,最终效果图如下: 我们看一下实现过程. 主框架是vue开发,做成了一个动画组件,因为涉及到多个页面引用,最主要的实现是css3语法实现过程,并且要做到循环播放. 左边出来动画时间是0.5秒,停留3秒往上走,然后动画时间0.5秒,停留3秒后然后消失,消失动画时间0.5秒,总共的时间消耗是7.5秒.可以得到以下计算比例 如果大家对编程,web前端感兴趣,想要学习,打算深入了解这个行业的朋友,可以加下我们的前端学习扣qun : 784783012 ,不论你是学生还是想转行的朋友,我

web前端入门到实战:CSS3 filter(滤镜)属性

css3的滤镜filter属性,可以对网页中的图片进行类似Photoshop图片处理的效果,例如背景的毛玻璃效果.老照片(黑白照片).火焰效果等. 一.blur(px)高斯模糊 二.brightness(%)亮度 三.contrast(%)对比度 四.drop-shadow()阴影 注意: 这个 drop-shadow 与 box-shadow 都是在说阴影,但还是有区别的,看下图 图中火焰的图片,是一张png图片,除了火焰以外,其他部分是透明的,我们能看见,box-shadow 是给整个图片加

web前端入门到实战:css3实现半圆和圆效果

在css2中,如果需要失效一些圆角或者半圆等等效果,一般是要通过ps等软件来处理的,在CSS3中,则不需要了,只需要通过border-radius就可以实现,大大方便了开发的效率. 无论圆角.圆弧.实心圆.半圆,css3的实现代码都是 border-radius 属性,border-radius 不但可以定义圆半径和圆角大小,还可以画出各种方向的半圆. 代码 <!DOCTYPE html> <html lang="en"> <head> <me

web前端入门到实战:CSS3中的弹性盒子模型

介绍 在css2当中,存在标准模式下的盒子模型和IE下的怪异盒子模型.这两种方案表示的是一种盒子模型的渲染模式.而在css3当中,新增加了弹性盒子模型,弹性盒子模型是一种新增加的强大的.灵活的布局方案.弹性盒子模型是css3中新提出的一种布局方案.是一种为了应对针对不同屏幕宽度不同设备的一整套新的布局方案.主要是对一个容器中的子元素进行排列.对齐和分配空白空间的方案的调整. 新旧版本的弹性盒子模型在之前,css3曾经推出过旧版本的弹性盒子模型.相对于新版本的弹性盒子模型而言,旧版本的内容与新版本

web前端入门到实战:CSS3制作文字背景图

文字带上渐变色,或者说让文字透出图片.这些效果 CSS 属性也可以完成. 方法一.利用CSS3属性mix-blend-mode:lighten;实现 使用 mix-blend-mode 能够轻易实现,我们只需要构造出黑色文字,白色底色的文字 div ,叠加上图片,再运用 mix-blend-mode 即可,简单原理如下: 核心代码如下: <div class="container"> <div class="pic"></div>

web前端入门到实战:css3动画 Transition

CSS transitions 提供了一种在更改CSS属性时控制动画速度的方法. 其可以让属性变化成为一个持续一段时间的过程,而不是立即生效的.比如,将一个元素的颜色从白色改为黑色,通常这个改变是立即生效的,使用 CSS transitions 后该元素的颜色将逐渐从白色变为黑色,按照一定的曲线速率变化.这个过程可以自定义. CSS transitions 可以决定哪些属性发生动画效果 (明确地列出这些属性),何时开始 (设置 delay),持续多久 (设置 duration) 以及如何动画 (

web前端入门到实战:css选择器和css文本样式相关

[文章来源微信公众号:每天学编程]---关注,后台领取编程资源 css基础-css选择器和css文本样式相关: 使用link链入外部样式,页面加载时会同时加载样式 @import url("*.css");使用导入式,页面加载完后,才会加载样式 链接伪类的顺序 :link-> :visited ->:hover-> :active 或者 : visited -> : link ->:hover-> :active 选择器的优先级: id选择器>

web前端入门到实战:HTML标签和JS中设置CSS3 var变量

一.HTML标签中设置CSS变量 如下: <div style="--color: #cd0000;"> <img src="mm.jpg" style="border: 10px solid var(--color);"> </div> 直接正常CSS语句一样在style属性中设置即可. 效果如下截图: 二.JS中设置CSS变量 如下,HTML示意: <div id="box">

web前端入门到实战:详解css3如何给背景图片加颜色遮罩

前段时间在开发中,遇到需要给背景层加颜色遮罩的项目,现在特定总结一下给背景图层加颜色遮罩的方法. 方法一:通过定位叠加(注意层级) <div class="wrap1"> <div class="inner"> </div> </div> .wrap1 { position: relative; width: 1200px; height: 400px; background: rgba(0, 0, 0, .5); }