Skip to content

Latest commit

 

History

History
317 lines (255 loc) · 6.8 KB

CSS3入门之转换.md

File metadata and controls

317 lines (255 loc) · 6.8 KB
title date
CSS3入门之转换
2017/02/21 14:47:10

1、CSS3 转换

1.1、转换是什么,能实现哪些效果?

转换是使元素改变形状、尺寸和位置的一种效果,主要能实现的效果如下:

  1. 移动
  2. 缩放
  3. 转动
  4. 拉长
  5. 拉伸

1.2、浏览器兼容

CSS3的转换属性为 transform ,IE10+,Firefox,Chrome,Opera,Safari等现代浏览器支持transform属性,IE9需要-ms-前缀。

2、 2D 转换

准备工作:

<style>
  .container{
    position:relative;border:1px solid red; width: 100px; height: 100px;
  }
  .container>div{
    width: 50px; height: 50px; background: gray;
  }
</style>
<style> .container{ position:relative;border:1px solid red; width: 100px; height: 100px; } .container div{ width: 50px; height: 50px; background: gray; } </style>

2.1、translate() -- 移动

translate(/*x坐标移动位移*/ left, /*y坐标移动位移*/ top)

<h3>右移20px</h3>
<div class="container">
  <div style="transform: translate(20px);"></div>
</div>
<h3>下移20px</h3>
<div class="container">
  <div style="transform: translate(0px,20px);"></div>
</div>
<h3>左移20px,下移20px</h3>
<div class="container">
  <div style="transform: translate(-20px,20px);"></div>
</div>

右移20px

下移20px

左移20px,下移20px

2.2、rotate() -- 旋转

rotate(/*旋转角度*/ deg)

<h3>旋转135度</h3>
<div class="container">
  <div style="transform: rotate(135deg);"></div>
</div>

旋转135度

2.3、scale() -- 缩放

scale(/*宽度缩放比例*/ widthScale, /*高度缩放比例*/ heightScale)

<h3>缩放到0.5倍</h3>
<div class="container">
  <div style="transform: scale(0.5, 0.5);"></div>
</div>
<h3>宽度缩放到1.5倍,高度缩放到0.25倍</h3>
<div class="container">
  <div style="transform: scale(1.5, 0.25);"></div>
</div>

缩放到0.5倍

宽度缩放到1.5倍,高度缩放到0.25倍

2.4、skew() -- 倾斜

skew(/*X轴倾斜角度*/ xDeg, /*Y轴倾斜角度*/ yDeg)

<h3>X轴翻转30度</h3>
<div class="container">
  <div style="transform: skew(30deg);"></div>
</div>
<h3>X轴翻转30度,Y轴翻转10度</h3>
<div class="container">
  <div style="transform: skew(30deg, 10deg)"></div>
</div>

X轴翻转30度

X轴翻转30度,Y轴翻转10度

2.5、matrix() --矩阵

<h3>旋转30度</h3>
<div class="container">
  <div style="transform: matrix(0.866,0.5,-0.5,0.866,0,0)"></div>
</div>

旋转30度

2.6 Transform方法

函数 描述
matrix(n,n,n,n,n,n) 定义 2D 转换,使用六个值的矩阵。
translate(x,y) 定义 2D 转换,沿着 X 和 Y 轴移动元素。
translateX(n) 定义 2D 转换,沿着 X 轴移动元素。
translateY(n) 定义 2D 转换,沿着 Y 轴移动元素。
scale(x,y) 定义 2D 缩放转换,改变元素的宽度和高度。
scaleX(n) 定义 2D 缩放转换,改变元素的宽度。
scaleY(n) 定义 2D 缩放转换,改变元素的高度。
rotate(angle) 定义 2D 旋转,在参数中规定角度。
skew(x-angle,y-angle) 定义 2D 倾斜转换,沿着 X 和 Y 轴。
skewX(angle) 定义 2D 倾斜转换,沿着 X 轴。
skewY(angle) 定义 2D 倾斜转换,沿着 Y 轴。

3、3D 转换

3.1、rotateX、rotateY

<div class="container">
  <div style="transform: rotateY(0deg)" id="fun2"></div>
</div>
<script>  
function fun2 (element) {
  var i = 0;
  var interval = setInterval(function(){
    element.style.transform = 'rotateY(' + i + 'deg)';
    i++;
  }, 5);
}
fun2(document.getElementById('fun2'));
</script>
<script> function fun2 (element) { var i = 0; var interval = setInterval(function(){ element.style.transform = 'rotateY(' + i + 'deg)'; i++; }, 5); } fun2(document.getElementById('fun2')); </script>

3.2、Transform方法

函数 描述
matrix3d(n,n,n,n,n,n,
n,n,n,n,n,n,n,n,n,n)
定义 3D 转换,使用 16 个值的 4x4 矩阵。
translate3d(x,y,z) 定义 3D 转化。
translateX(x) 定义 3D 转化,仅使用用于 X 轴的值。
translateY(y) 定义 3D 转化,仅使用用于 Y 轴的值。
translateZ(z) 定义 3D 转化,仅使用用于 Z 轴的值。
scale3d(x,y,z) 定义 3D 缩放转换。
scaleX(x) 定义 3D 缩放转换,通过给定一个 X 轴的值。
scaleY(y) 定义 3D 缩放转换,通过给定一个 Y 轴的值。
scaleZ(z) 定义 3D 缩放转换,通过给定一个 Z 轴的值。
rotate3d(x,y,z,angle) 定义 3D 旋转。
rotateX(angle) 定义沿 X 轴的 3D 旋转。
rotateY(angle) 定义沿 Y 轴的 3D 旋转。
rotateZ(angle) 定义沿 Z 轴的 3D 旋转。
perspective(n) 定义 3D 转换元素的透视视图。