• CSS3入门之转换


    CSS3入门之转换

    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;  100px; height: 100px;
      }
      .container>div{
         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>
    
     

    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 转换元素的透视视图。
  • 相关阅读:
    Python基础-编码转化
    Python基础-简要说明
    Python基础-流程控制
    Python基础-运算符
    Python基础-输入输出
    博客更新第一天 愿在前端路上 坚定不移 多累积
    bower解决js库的依赖管理
    NPM下载出错 No compatible version found
    jquery-1.10.2 获取checkbox的checked属性总是undefined
    HTML中的下拉列表 select
  • 原文地址:https://www.cnblogs.com/humin/p/4944970.html
Copyright © 2020-2023  润新知