CSS新特性2

转换

转换的效果是让某个元素改变形状,大小和位置

transform属性向元素应用 2D 或 3D 转换。该属性允许我们对元素进行旋转、缩放、移动或倾斜

html 复制代码
<div class="box"></div>
.box {
  width: 100px;
  height: 80px;
  background-color: rgba(255, 0, 0, .8);
  transform: translate(50px, 100px);
}
html 复制代码
<div class="box"></div>
.box {
  width: 100px;
  height: 80px;
  background-color: rgba(255, 0, 0, .8);
  transform: rotate(30deg);
}
html 复制代码
<div class="box"></div>
.box {
  width: 100px;
  height: 80px;
  background-color: rgba(255, 0, 0, .8);
  transform: scale(2,3); 
}

3D转换

CSS3 允许您使用 3D 转换来对元素进行格式化

  1. rotateX()
  2. rotateY()
html 复制代码
<div class="box"></div>
.box {
  width: 200px;
  height: 250px;
  background-color: #8ac007;
  margin: 50px;
}
.box:hover{
  box-shadow: 0 15px 30px rgba(0,0,0,0.2);
  transform: translate3d(0,-2px,0);
}

过渡

html 复制代码
<div class="box"></div>
.box {
  width: 100px;
  height: 80px;
  background-color: rgba(255, 0, 0, .8);
  transition: width 2s ease 1s;
}
.box:hover{
  width: 500px;
}

动画

动画是使元素从一种样式逐渐变化为另一种样式的效果

您可以改变任意多的样式任意多的次数

请用百分比来规定变化发生的时间,或用关键词 "from" 和 "to",等同于 0% 和 100%

0% 是动画的开始,100% 是动画的完成。

@keyframes创建动画

使用@keyframes规则,你可以创建动画

html 复制代码
@keyframes name {
  from|0%{
       css样式
   }
  percent{
       css样式
   }
  to|100%{
       css样式
   }
}

切换背景颜色

html 复制代码
<div class="animation"></div>
.animation {
  width: 300px;
  height: 300px;
  background-color: red;
  animation: anima 5s linear 5s infinite;
}
.animation:hover {
  animation-play-state: paused;
}
@keyframes anima {
  0% {
    background-color: red;
   }
  50% {
    background-color: green;
   }
  100% {
    background-color: blueviolet;
   }
}

呼吸效果

html 复制代码
<div class="box"></div>
.box {
  width: 500px;
  height: 400px;
  margin: 40px auto;
  background-color: #2b92d4;
  border-radius: 5px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .3);
  /* animation-timing-function: ease-in-out;
   animation-name: breathe;
   animation-duration: 2700ms;
   animation-iteration-count: infinite;
   animation-direction: alternate; */
  animation: breathe 2700ms ease-in-out infinite alternate;
}
@keyframes breathe {
  0% {
    opacity: .2;
    box-shadow: 0 1px 2px rgba(255, 255, 255, 0.1)
   }
  50% {
    opacity: .5;
    box-shadow: 0 1px 2px rgba(18, 190, 84, 0.76)
   }
  100% {
    opacity: 1;
    box-shadow: 0 1px 30px rgba(59, 255, 255, 1)
   }
}
相关推荐
西西学代码5 分钟前
Flutter---SingleChildScrollView
前端·javascript·flutter
ZTLJQ12 分钟前
构建现代Web应用:Python全栈框架完全解析
前端·数据库·python
前端付豪16 分钟前
实现代码块复制和会话搜索
前端·人工智能·后端
英俊潇洒美少年21 分钟前
Vue reactive 底层 Proxy 完整流程(依赖收集 + 触发更新)
前端·javascript·vue.js
周万宁.FoBJ21 分钟前
vue源码讲解之 effect解析 (仅包含在effect中使用reacitve情况)
前端·javascript·vue.js
Qlittleboy26 分钟前
<el-form @submit.native.prevent> elementUI的里面的input的元素的回车事件后总是自动提交表单
前端·javascript·elementui
Carsene26 分钟前
Docsify 文档缓存问题终极解决方案:拦截请求自动添加版本号
前端·javascript
周淳APP28 分钟前
【VDOM,Diff算法,生命周期,并发请求】
前端·javascript·vue.js
Linncharm28 分钟前
重写一个「年久失修」的开源项目:把 jQuery + CoffeeScript 的 3D 户型图工具迁移到 TypeScript + Three.js r181
前端
竹林81830 分钟前
从“后端验证”到“前端签名”:我在Web3项目中重构用户身份认证的实战记录
前端·javascript