十天领会CSS三(捌)

十天领会CSS三(捌)

卡通过渡(transition)

图片 1

      案例1:

变形–扭曲 skew()

扭曲skew()函数能够让要素倾斜显示。它可以将多少个目的以其主旨地点围绕着X轴Y轴依据一定的角度倾斜。那与rotate()函数的团团转分化,rotate()函数只是旋转,而不会改动成分的造型。skew()函数不会旋转,而只会变动成分的模样。

Skew()具备两种意况:

一、skew(x,y)使成分在档期的顺序和垂直方向同时扭曲(X轴和Y轴同时按自然的角度值进行翻调换形);

图片 2

率先个参数对应X轴,第2个参数对应Y轴。纵然第1个参数未提供,则值为0,也便是Y轴方向上无斜切。

二、skewX(x)仅使元素在档案的次序方向扭曲变形(X轴扭曲变形);

图片 3

3、skewY(y)仅使成分在笔直方向扭曲变形(Y轴扭曲变形)

图片 4

示范演示:

经过skew()函数将正方形产生平行4边形。

HTML代码:

<div class="wrapper">
  <div>我变成平形四边形</div>
</div>

CSS代码:

.wrapper {
  width: 300px;
  height: 100px;
  border: 2px dotted red;
  margin: 30px auto;
}
.wrapper div {
  width: 300px;
  height: 100px;
  line-height: 100px;
  text-align: center;
  color: #fff;
  background: orange;
  -webkit-transform: skew(45deg);
  -moz-transform:skew(45deg) 
  transform:skew(45deg);
}

演示结果

图片 5

4.1.5 matrix() 方法

图片 6

matrix()方法和二D调换格局统1/10三个。

matrix 方法有八个参数,包涵旋转,缩放,移动(平移)和倾斜功效。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:matrix(0.866,0.5,-0.5,0.866,0,0);
    -ms-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* IE 9 */
    -webkit-transform:matrix(0.866,0.5,-0.5,0.866,0,0); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

2D转换

在2维的平面上做一些变型,使用transform属性

  二、二d改造模块transform

卡通–过渡所需时间 transition-duration

transition-duration属性首要用来设置贰个属性过渡到另一个属性所需的年月,相当于从旧属性过渡到新属性开支的岁月长短,俗称持续时间

案例演示:

在鼠标悬停(hover)状态下,让容器从直角日趋过渡到圆角,并让一切动画持续0.伍s。

HTML:

<div></div>

CSS:

div {
  width: 300px;
  height: 200px;
  background-color: orange;
  margin: 20px auto;
  -webkit-transition-property: -webkit-border-radius;
  transition-property: border-radius;
  -webkit-transition-duration: .5s;
  transition-duration: .5s;
  -webkit-transition-timing-function: ease-out;
  transition-timing-function: ease-out;
  -webkit-transition-delay: .2s;
  transition-delay: .2s;
}
div:hover {
  border-radius: 20px;
}

以身作则结果:

鼠标移入

图片 7

鼠标移出

图片 8

4.1.6 CSS3 transform 属性

Transform属性应用于成分的2D或3D转变。

那些特性允许你将成分旋转,缩放,移动,倾斜等。

transform: none|transform-functions;

描述
none 定义不进行转换。
matrix(n,n,n,n,n,n) 定义 2D 转换,使用六个值的矩阵。
matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4×4 矩阵。
translate(x,y) 定义 2D 转换。
translate3d(x,y,z) 定义 3D 转换。
translateX(x) 定义转换,只是用 X 轴的值。
translateY(y) 定义转换,只是用 Y 轴的值。
translateZ(z) 定义 3D 转换,只是用 Z 轴的值。
scale(x[,y]?) 定义 2D 缩放转换。
scale3d(x,y,z) 定义 3D 缩放转换。
scaleX(x) 通过设置 X 轴的值来定义缩放转换。
scaleY(y) 通过设置 Y 轴的值来定义缩放转换。
scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。
rotate(angle) 定义 2D 旋转,在参数中规定角度。
rotate3d(x,y,z,angle) 定义 3D 旋转。
rotateX(angle) 定义沿着 X 轴的 3D 旋转。 测试
rotateY(angle) 定义沿着 Y 轴的 3D 旋转。
rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。
skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。
skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。
skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。
perspective(n) 为 3D 转换元素定义透视视图。
    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:200px;
    height:100px;
    background-color:yellow;
    /* Rotate div */
    transform:rotate(7deg);
    -ms-transform:rotate(7deg); /* IE 9 */
    -webkit-transform:rotate(7deg); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>Hello</div>

    </body>
    </html>

案例:旋转图片

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    body
    {
    margin:30px;
    background-color:#E9E9E9;
    }

    div.polaroid
    {
    width:294px;
    padding:10px 10px 20px 10px;
    border:1px solid #BFBFBF;
    background-color:white;
    /* Add box-shadow */
    box-shadow:2px 2px 3px #aaaaaa;
    }

    div.rotate_left
    {
    float:left;
    -ms-transform:rotate(7deg); /* IE 9 */
    -webkit-transform:rotate(7deg); /* Safari and Chrome */
    transform:rotate(7deg);
    }

    div.rotate_right
    {
    float:left;
    -ms-transform:rotate(-8deg); /* IE 9 */
    -webkit-transform:rotate(-8deg); /* Safari and Chrome */
    transform:rotate(-8deg);
    }
    </style>
    </head>
    <body>

    <div class="polaroid rotate_left">
    [站外图片上传中……(30)]
    <p class="caption">The pulpit rock in Lysefjorden, Norway.</p>
    </div>

    <div class="polaroid rotate_right">
    [站外图片上传中……(31)]
    <p class="caption">Monterosso al Mare. One of the five villages in Cinque Terre.</p>
    </div>


    </body>
    </html>

 1. 3D转换之X轴旋转

图片 9

※  X轴转动就好像单杠旋转

案例:

 

 

        div{
            width: 200px;
            height: 200px;
            margin: 100px auto;
            border: #000 solid 1px;
        }
        div img:hover{
            transform: rotateX(60deg);/*x轴旋转60度*/
        }

 

 

☞ transform: rotateX(60deg)在二维平面,没有立体感。想让它有立体感需要添加透视功能()

 

透视点(延长会有一个相交点)– 灭点 
 

 

 

        div{
            width: 200px;
            height: 200px;
            margin: 100px auto;
            border: #000 solid 1px;
            perspective: 400px; /*透视效果,这个元素必须给父元素添加*/
        }        div img:hover{
            transform: rotateX(60deg);/*x轴旋转60度*/
        }

 

 暗中认可意况以中线在转悠,加多transform-origin: bottom以底边为原点

 

 

        div{
            width: 200px;
            height: 200px;
            margin: 100px auto;
            border: #000 solid 1px;
            perspective: 400px; /*透视效果,这个元素必须给父元素添加*/
        }
        div img{
            transform-origin: bottom;
            transition: all 0.5s;
        }
        div img:hover{
            transform: rotateX(60deg);/*x轴旋转60度*/
        }

 

 

案例:张开的盒子

 

 

    #content{
        width: 300px;
        height: 300px;
        margin: 100px auto;
        position: relative;
    }
    #content #face1,
    #content #face2{
        width: 300px;
        height: 300px;
        border-radius: 50%;
        background: url('turntable-bg.jpg') no-repeat;
        border: #666 solid 1px;
        position: absolute;
        left: 0;
        top: 0;
    }
    #content #face2{
        background: url('turntable.png') no-repeat;
        transform-origin: bottom;
        transition: all 2s;
    }
    #content:hover #face2{
        transform: rotateX(180deg);
    }

 

 

    2、必须告诉系统哪个属性需求实践过渡效果

卡通–过渡函数 transition-timing-function

transition-timing-function属性指的是联网的“缓动函数”。首要用于钦定浏览器的过渡速度,以及连接时期的操作进行意况,在这之中要包蕴以下两种函数:

图片 10

(单击图片可拓宽)

案例展现:

在hover状态下,让容器从二个正方形逐步过渡到3个圆形,而整个过渡是先增加速度再减速,也正是运用ease-in-out函数。

HTML代码:

<div></div>

CSS代码:

div {
  width: 200px;
  height: 200px;
  background: red;
  margin: 20px auto;
  -webkit-transition-property: -webkit-border-radius;
  transition-property: border-radius;
  -webkit-transition-duration: .5s;
  transition-duration: .5s;
  -webkit-transition-timing-function: ease-in-out;
  transition-timing-function: ease-in-out;
  -webkit-transition-delay: .2s;
  transition-delay: .2s;
}
div:hover {
  border-radius: 100%;
}

以身作则结果

鼠标移入:

图片 11

鼠标移出:

图片 12

4.1.3 scale() 方法

图片 13

scale()方法,该因素增添或回落的深浅,取决于宽度(X轴)和冲天(Y轴)的参数:

scale(二,肆)调换宽度为本来的大大小小的贰倍,和其固有大小4倍的可观。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    margin:100px;
    transform:scale(2,4);
    -ms-transform:scale(2,4); /* IE 9 */
    -webkit-transform:scale(2,4); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

1. 二D转换之移动(translate)

案例:

        div{
            width: 200px;
            height: 200px;
            background-color: #090;
            position: absolute;
            left: 50%;
            top: 50%;
            transform: translate(-50%,-50%);/*左-上 移动自身50%*/
        }
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>过渡模块-手风琴效果</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        ul{
            width: 960px;
            height: 300px;
            margin: 100px auto;
            border: 1px solid #000;
            overflow: hidden;
        }
        ul li{
            list-style: none;
            width: 160px;
            height: 300px;
            float: left;
            transition: width 0.5s;
        }
        ul:hover li{
            width: 100px;
        }
        ul li:hover{
            width: 460px;
        }
    </style>
</head>
<body>
<ul>
/*这里为了方便使用了行内样式表,实际应用中一般为图片,要注意样式与内容分离*/

    <li style="background-color: #ccc;"></li>
    <li style="background-color: #e5ce8a;"></li>
    <li style="background-color: #eac123;"></li>
    <li style="background-color: #a00;"></li>
    <li style="background-color: #cc0;"></li>
    <li style="background-color: #0cc;"></li>
</ul>
</body>
</html>

变形–缩放 scale()

缩放 scale()函数 让要素依照核心原点对目的开始展览缩放。

缩放 scale 具有两种处境:

1、 scale(X,Y)使成分水平方向和垂直方向同时缩放(也正是X轴和Y轴同时缩放)

图片 14

例如:

div:hover {
  -webkit-transform: scale(1.5,0.5);
  -moz-transform:scale(1.5,0.5)
  transform: scale(1.5,0.5);
}

注意:Y是三个可选参数,借使未有设置Y值,则象征X,Y八个方向的缩放倍数是如出1辙的。

二、scaleX(x)成分仅水平方向缩放(X轴缩放)

图片 15

三、scaleY(y)成分仅垂直方向缩放(Y轴缩放)

图片 16

HTML代码:

<div class="wrapper">
  <div>我将放大1.5倍</div>
</div>

CSS代码:

.wrapper {
  width: 200px;
  height: 200px;
  border:2px dashed red;
  margin: 100px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  line-height: 200px;
  background: orange;
  text-align: center;
  color: #fff;
}
.wrapper div:hover {
  opacity: .5;
  -webkit-transform: scale(1.5);
  -moz-transform:scale(1.5)
  transform: scale(1.5);
}

演示结果

图片 17

注意: scale()的取值暗中同意的值为一,当班值日设置为0.010.99以内的别的值,功用使1个要素缩短;而任何大于或等于1.01的值,成效是让要素放大。

2. 倒影

3D转换

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>旋转轴向</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        ul{
            width: 800px;
            height: 500px;
            margin: 0 auto;
        }
        ul li{
            list-style: none;
            width: 200px;
            height: 200px;
            margin: 0 auto;
            margin-top: 50px;
            border: 1px solid #000;
            transform:perspective(500px);
       }
        ul li div{
            width: 200px;
            height: 200px;
            background-color: #ac4345;
        }
        ul li:nth-child(1) div{
            transform: rotateZ(45deg);
        }
        ul li:nth-child(2) div{
            transform: rotateX(45deg);
        }
        ul li:nth-child(3) div{
            transform: rotateY(45deg);
        }
    </style>
</head>
<body>
<ul>
    <li><div></div></li>
    <li><div></div></li>
    <li><div></div></li>
</ul>
</body>
</html>

变形–矩阵 matrix()

matrix() 是1个含五个值的(a,b,c,d,e,f)转变矩阵,用来钦命三个2D调换,也正是直接利用一个[a
b c d e
f]转移矩阵。正是依照水平方向(X轴)和垂直方向(Y轴)重新定位元素,此属性值使用涉及到数学中的矩阵,小编在那边只是简短的说一下CSS三中的transform有这么一个属性值,借使供给深远摸底,须要对数学矩阵有早晚的学问。

演示演示:透过matrix()函数来效仿transform中translate()位移的机能。
HTML代码:

<div class="wrapper">
  <div></div>
</div>

CSS代码:

.wrapper {
  width: 300px;
  height: 200px;
  border: 2px dotted red;
  margin: 40px auto;
}
.wrapper div {
  width:300px;
  height: 200px;
  background: orange;
  -webkit-transform: matrix(1,0,0,1,50,50);
  -moz-transform:matrix(1,0,0,1,50,50);
  transform: matrix(1,0,0,1,50,50);
}

示范结果:

图片 18

4.1.2 rotate() 方法

图片 6

rotate()方法,在1个给定度数顺时针旋转的要素。负值是允许的,那样是因素逆时针转动。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:rotate(30deg);
    -ms-transform:rotate(30deg); /* IE 9 */
    -webkit-transform:rotate(30deg); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>你好。这是一个 DIV 元素。</div>

    <div id="div2">你好。这是一个 DIV 元素。</div>

    </body>
    </html>

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>2D转换模块的形变中心点</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        ul{
            width: 200px;
            height: 200px;
            border: 1px solid #000;
            margin: 100px auto;
            position: relative;
        }
        ul li{
            list-style: none;
            width: 200px;
            height: 200px;
            position: absolute;
            left: 0;
            top: 0;
            transform-origin: left top;
        }
        ul li:nth-child(1){
            background-color: red;
            transform: rotate(30deg);
        }
        ul li:nth-child(2){
            background-color: green;
            transform: rotate(50deg);
        }
        ul li:nth-child(3){
            background-color: blue;
            transform: rotate(70deg);
        }
    </style>
</head>
<body>
<ul>
    <li></li>
    <li></li>
    <li></li>
</ul>
</body>
</html>

变形–旋转 rotate()

旋转rotate()函数通过点名的角度参数使成分相对原点实行旋转。它最首要在2维空间内开始展览操作,设置1个角度值,用来钦赐旋转的上涨的幅度。若是这几个值为正值,成分相对原点焦点顺时针旋转;若是那些值为负值,成分相对原点中央逆时针旋转。如下图所示:

图片 20

HTML代码:

<div class="wrapper">
  <div></div>
</div>

CSS代码:

.wrapper {
  width: 200px;
  height: 200px;
  border: 1px dotted red;
  margin: 100px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  background: orange;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

以身作则结果

图片 21

 

4.1.4 skew() 方法

图片 22

skew()方法,该成分会根据横向(X轴)和垂直(Y轴)线参数给定角度:

skew(30deg,20deg)是绕X轴和Y轴周边20度30度的成分。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:skew(30deg,20deg);
    -ms-transform:skew(30deg,20deg); /* IE 9 */
    -webkit-transform:skew(30deg,20deg); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

 二. 二D改换之旋转(rotate)

暗中同意意况下按宗旨点旋转,大家得以因而transform-origin调主旨点。

        div{
            width: 200px;
            height: 200px;
            background-color: #090;
            margin: 100px auto;
            transform-origin: top left;/*旋转的中心点,默认不写该属性是以矩形中心点旋转*/
        }
        div:hover{
            transform: rotate(45deg)/*deg表示度数*/
        }

    3、必须告诉系统接入效果不断时间长度

变形–位移 translate()

translate()函数能够将成分向钦赐的倾向移动,类似于position中的relative。或以轻易的敞亮为,使用translate()函数,能够把成分从原本的岗位移动,而不影响在X、Y轴上的任何Web组件。

translate大家分为二种情况:

壹、translate(x,y)水平方向和垂直方向同时活动(也正是X轴和Y轴同时活动)

图片 23

贰、translateX(x)仅水平方向移动(X轴移动)

图片 24

3、translateY(Y)仅垂直方向移动(Y轴移动)

图片 25

实例演示:通过translate()函数将成分向Y轴下方移动50px,X轴右方移动100px。

HTML代码:

<div class="wrapper">
  <div>我向右向下移动</div>
</div>

CSS代码:

.wrapper {
  width: 200px;
  height: 200px;
  border: 2px dotted red;
  margin: 20px auto;
}
.wrapper div {
  width: 200px;
  height: 200px;
  line-height: 200px;
  text-align: center;
  background: orange;
  color: #fff;
  -webkit-transform: translate(50px,100px);
  -moz-transform:translate(50px,100px);
  transform: translate(50px,100px);
}

以身作则结果

图片 26

请各位读者增添一下笔者的微信公众号,未来有新的篇章,就要微信公众号一向推送给各位,相当多谢。

图片 27

假设你以为那篇小说还不易,能够去H5专题中查阅更加多相关小说。

 3. 二D转移之缩放(scale)

        div{
            width: 200px;
            height: 200px;
            background-color: #090;
            margin: 100px auto;
        }
        div:hover{
            /*transform: scale(0.5);*/ /*x轴和Y轴都是缩放0.5倍*/
            /*transform: scaleX(0.5);*/ /*x轴缩放0.5倍*/
            transform: scale(2,3); /*x轴缩放2倍 y轴缩放3倍*/
        }

   今日,我们壹道来钻探一下css三中的过渡模块、贰d转移模块和三d转变模块

变形–原点 transform-origin

别的1个因素都有一个基本点,暗中认可景况之下,个中央点是高居成分X轴和Y轴的二分一处。如下图所示:

图片 28

在并未有重新初始化transform-origin改动成分原点地点的状态下,CSS变形举行的旋转、位移、缩放,扭曲等操作皆以以成分和煦宗旨地方张开变形。但不少时候,大家能够通过transform-origin来对成分实行原点地方变动,使成分原点不在元素的大旨地点,以到达要求的原点地方。

transform-origin取值和要素设置背景中的background-position取值类似,如下表所示:

图片 29

示范呈现:

透过transform-origin改换元素原点到左上角,然后开始展览顺时旋转四伍度。

HTML代码:

<div class="wrapper">
  <div>原点在默认位置处</div>
</div>
<div class="wrapper transform-origin">
  <div>原点重置到左上角</div>
</div>

CSS代码:

.wrapper {
  width: 300px;
  height: 300px;
  float: left;
  margin: 100px;
  border: 2px dotted red;
  line-height: 300px;
  text-align: center;
}
.wrapper div {
  background: orange;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
.transform-origin div {
  -webkit-transform-origin: left top;
  transform-origin: left top;
}

演示结果:

图片 30

4.2.2 rotateY() 方法

图片 31

rotateY()方法,围绕其在二个给定度数Y轴转动的成分。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:rotateY(130deg);
    -webkit-transform:rotateY(130deg); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <p><b>Note:</b> Internet Explorer 9 (and earlier versions) and Opera does not support the rotateY method.</p>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

 四. 二D转移之斜切(skew)

        div{
            width: 200px;
            height: 200px;
            background-color: #090;
            margin: 100px auto;
        }
        div:hover{
            /*transform: skewX(8deg);*/ /*x方向上斜切8度*/
            transform: skewY(8deg); /*y方向上斜切8度*/
        }
  1. 改变案例:

下箭头制作

图片 32

 1         div{
 2             width: 300px;
 3             height: 40px;
 4             border: #5c5c5c solid 1px;
 5             margin: 100px auto;
 6             position: relative;
 7         }
 8         div::after{
 9             content: '';
10             width: 12px;
11             height: 12px;
12             border-right: #5c5c5c solid 2px;
13             border-bottom: #5c5c5c solid 2px;
14             display: block;
15             position: absolute;
16             top: 50%; /*子盒子左上角相对于有定位的父盒子居中显示*/
17             right: 12px;
18             transform: translateY(-50%) rotate(45deg); /*translateY(-50%)与top:50% 组合使用让子盒子相对父盒子垂直居中*/
19         }
20         div:hover{
21             border: #009 solid 1px;
22         }
23         div:hover::after{
24             border-right: #009 solid 2px;
25             border-bottom: #009 solid 2px;
26         }

 

动画片–过渡延迟时间 transition-delay

transition-delay属性transition-duration属性极端类似,分化的是transition-duration是用来设置过渡动画的持续时间,而transition-delay首要用以钦命3个卡通开头实行的日子,约等于说当退换成分属性值后多久起先实行。

神跡大家想更动八个大概多个css属性的transition效果时,只要把几个transition的宣示串在壹块儿,用逗号(“,”)隔断,然后分别能够有各自差别的接轨时间和其时刻的速率调换方式。但需求值得注意的少数:第一个时刻的值为
transition-duration,第3个为transition-delay。

例如:a{ transition:
background 0.8s ease-in 0.3,color 0.6s ease-out 0.3;}

以身作则演示:

经过transition属性将一个200px
*200px的海水绿容器,在鼠标悬浮状态时,过渡到三个300px *
300px的新民主主义革命容器。而且全数过渡0.①s后触发,并且整个过渡持续0.28s。

HTML代码:

<div class="wrapper">
  <div>鼠标放到我的身上来</div>
</div>

CSS代码:

.wrapper {
  width: 400px;
  height: 400px;
  margin: 20px auto;
  border: 2px dotted red;
}
.wrapper div {
  width: 200px;
  height: 200px;
  background-color: orange;
  -webkit-transition: all .28s ease-in .1s;
  transition: all .28s ease-in .1s;
}
.wrapper div:hover {
  width: 300px;
  height: 300px;
  background-color: red;
}

示范结果

鼠标移入:

图片 33

鼠标移出:

图片 34

3. 过渡

通过 CSS3transition,我们得以在不采纳 Flash 动画或
JavaScript
的情形下,当成分从壹种体制调换为另1种体裁时为因素增添效果。

CSS三 过渡是因素从一种样式逐步改变为另1种的机能。

要促成那点,必须分明两项内容:

  • 点名要增添效果的CSS属性
  • 点名效果的持续时间。

使用于宽度属性的交接效果,时间长度为 二 秒:

div
{
transition: width 2s;
-webkit-transition: width 2s; /* Safari */
}

留神: 如若未钦命的定时,transition将尚未其余效果,因为暗中认可值是0。

点名的CSS属性的值更动时效劳会产生变化。三个标准CSS属性的变化是用户鼠标放在三个成分上时:

规定当鼠标指针悬浮(:hover)于 <div>要素上时:

样例代码:

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:100px;
    background:red;
    transition:width 2s;
    -webkit-transition:width 2s; /* Safari */
    }

    div:hover
    {
    width:300px;
    }
    </style>
    </head>
    <body>

    <p><b>注意:</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>

    <div></div>

    <p>鼠标移动到 div 元素上,查看过渡效果。</p>

    </body>
    </html>

多项改成

要加多多个样式的更改效果,加多的性质由逗号分隔:

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div {
        width: 100px;
        height: 100px;
        background: red;
        -webkit-transition: width 2s, height 2s, -webkit-transform 2s; /* For Safari 3.1 to 6.0 */
        transition: width 2s, height 2s, transform 2s;
    }

    div:hover {
        width: 200px;
        height: 200px;
        -webkit-transform: rotate(180deg); /* Chrome, Safari, Opera */
        transform: rotate(180deg);
    }
    </style>
    </head>
    <body>
    <p><b>注意:</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>

    <div>鼠标移动到 div 元素上,查看过渡效果。</div>
    </body>
    </html>
属性 描述
transition 简写属性,用于在一个属性中设置四个过渡属性。
transition-property 规定应用过渡的 CSS 属性的名称。
transition-duration 定义过渡效果花费的时间。默认是 0。
transition-timing-function 规定过渡效果的时间曲线。默认是 "ease"。
transition-delay 规定过渡效果何时开始。默认是 0。
    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:100px;
    background:red;
    transition-property:width;
    transition-duration:1s;
    transition-timing-function:linear;
    transition-delay:2s;
    /* Safari */
    -webkit-transition-property:width;
    -webkit-transition-duration:1s;
    -webkit-transition-timing-function:linear;
    -webkit-transition-delay:2s;
    }

    div:hover
    {
    width:200px;
    }
    </style>
    </head>
    <body>

    <p><b>注意:</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>



    <div></div>

    <p>鼠标移动到 div 元素上,查看过渡效果。</p>
    <p><b>注意:</b> 过渡效果需要等待两秒后才开始。</p>

    </body>
    </html>

与地点的事例同样的连通效果,不过利用了简写的 transition 属性:

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:100px;
    background:red;
    transition:width 1s linear 2s;
    /* Safari */
    -webkit-transition:width 1s linear 2s;
    }

    div:hover
    {
    width:200px;
    }
    </style>
    </head>
    <body>

    <p><b>注意:</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>

    <div></div>

    <p>鼠标移动到 div 元素上,查看过渡效果。</p>
    <p><b>注意:</b> 过渡效果需要等待两秒后才开始。</p>

    </body>
    </html>

    例如:一个div标签嵌套了一个img标签和span标签(img和span是同级标签)
    <!--设置图片高度-->
    img{
       height: 218px;
      }
     <!--设置span标签的属性--> 
    span{
        height: 30px;
        width: 100%;
        font-size: 16px;
        color: white;
        text-align: center;;
        line-height: 30px;
        position: absolute;
        left: 0;
        bottom: 0;
        <!--设置开始透明度为0,也就是不显示-->
        opacity: 0;
        <!--设置0.5过渡-->
        transition:all .5s;
      }
      hover 伪类选择器用于选择鼠标指针浮动在上面的元素时触发;对于此时而言,就是鼠标指针浮动在div标签上时,显示span标签上的字体;
    div:hover span{
       <!--设置透明度为1,也就是显示-->
       opacity: 1;
      }

显示效果如下图所示:

图片 35

transition展现效果

庞大属性:

  • transition-property 规定采纳接入的 CSS 属性的名称。
  • transition-duration 定义过渡效果耗费的光阴。暗许是 0。
  • transition-timing-function 规定过渡效果的年华曲线。暗中同意是 “ease”。
  • transition-delay 规定过渡效果何时开头。默许是 0。
  • transition 简写属性,用于在2本质量中安装八个对接性质。

2. 3D转换之X轴旋转

图片 36

 ※  Y轴转动就像钢管舞,沿着y轴方向旋转

 

 1 #content{
 2     width: 300px;
 3     height: 300px;
 4     border: #666 solid 1px;
 5     margin: 100px auto;
 6     position: relative;
 7     perspective: 800px; /*如需透视效果景深,这个元素必须给父元素添加*/
 8 }
 9 #content #face1,
10 #content #face2{
11     width: 300px;
12     height: 300px;
13     border-radius: 50%;
14     background: url('yingbi.png') no-repeat;
15     position: absolute;
16     backface-visibility: hidden; /*转过去以后隐藏*/
17     transition: all 3s;
18 }
19 #content #face1{
20     background-position: -4px -3px;
21     z-index: 1;
22 }
23 #content #face2{
24     background-position: -358px -3px;
25     transform: rotateY(-180deg); /*face2在背面处于-180度的状态*/
26     /* z-index: 0; */
27 }
28 #content:hover #face1{
29     transform: rotateY(-180deg);
30     /* z-index: 0; */ /*旋转过后置于底部  有了backface-visibility: hidden可不添加*/
31 }
32 #content:hover #face2{
33     transform: rotateY(0deg);
34     /* z-index: 1; */ /*旋转过后置于顶部 */
35 }

 

 素材可下载  

 

 

face②在背面处于-180度的情状

        我们能够透过ul的:hover事件让具有的li变小,然后经过li的:hover时间来使当前li宽度变大。案例事小,思路是大,这种思路在事后的js中照旧其它的地点平日利用,即先将具备因素开端化,在单独改变须求改动的因素属性。

动画片–过渡性质 transition-property

最初在Web中要贯彻动画效果,都以依赖于JavaScript或Flash来达成。但在CSS3中新追加了3个新的模块transition,它能够经过有个别轻便的CSS事件来触发成分的外观变化,让效果显得愈发细致。轻便题说,哪怕通过鼠标的单击、得到主旨,被点击或对成分任何更改中触发,并平滑地以动画片效果改换CSS的属性值。

在CSS中创建简单的过渡效果可以从以下几个步骤来实现:
第一,在默认样式中声明元素的初始状态样式;
第二,声明过渡元素最终状态样式,比如悬浮状态;
第三,在默认样式中通过添加过渡函数,添加一些不同的样式。

CSS叁的过度transition属性是二个复合属性,主要不外乎以下多少个子属性:

  • transition-property:钦命过渡或动态模拟的CSS属性

  • transition-duration:内定完结联网所需的时刻

  • transition-timing-function:钦定过渡函数

  • transition-delay:钦赐初叶产出的延迟时间

先来看transition-property属性

transition-property用来钦命联网动画的CSS属性名称,而那几个过渡性质唯有全部3个中式点心值的品质(须要发出动画的特性)技巧有所过渡效果,其对应有所过渡的CSS属性首要有:

图片 37

HTML:

<div></div>

CSS:

div {
  width: 200px;
  height: 200px;
  background-color:red;
  margin: 20px auto;
  -webkit-transition: background-color .5s ease .1s;
  transition: background-color .5s ease .1s;
}
div:hover {
  background-color: orange;
}

以身作则结果:

鼠标移入

图片 38

鼠标移出

图片 39

特别注意:当“transition-property”属性设置为all时,表示的是怀有中式点心值的属性。

用一个粗略的例证来证明这些主题材料:

一旦你的始发状态设置了体制“width”,“height”,“background”,当您在终始状态都转移了那四个属性,那么all表示的正是“width”、“height”和“background”。就算你的终始状态只退换了“width”和“height”时,那么all代表的正是“width”和“height”。

CSS叁尖端属性

图片 40

此间写图片描述

动漫过渡类型:

图片 41

 

 案例:

尚未给transition瞬间转换 ↓ ↓

        div{
            width: 200px;
            height: 100px;
            border: #00f solid 3px;
            background-color: #f90;
            margin: 100px auto;
            border-radius: 15px;
        }
        div:hover{
            width: 300px;
            height: 200px;
            background-color: #f30;
        }

1. 连接的小案例:

        div{
            width: 200px;
            height: 100px;
            border: #00f solid 3px;
            background-color: #f90;
            margin: 100px auto;
            border-radius: 15px;
            /*transition: width 0.5s ease 0s;*/ /* 设置参与过渡的属性 过渡时间 过渡的动画类型 延迟过渡的时间 */
            /*transition: all 0.5s ease 1s;*/ /* 默认用all参与 ... 延迟时间【进入和退出动画都延迟2秒】 */
            transition: all 0.5s;
        }
        div:hover{
            width: 300px;
            height: 200px;
            background-color: #f30;
        }

 

二. 头像旋转小案例:

 

        img{
            border: #093 solid 4px;
            display: block;
            margin: 100px auto;
            border-radius: 50%;
            width: 300px;
            height: 300px;
            transition: all 1s;
        }
        img:hover{
            transform: rotate(360deg);
        }

 

三.
鼠标移动到图片上海体育场合片变大(模仿公开课网址的效劳) 

        div{
            width: 300px;
            height: 300px;
            border: #ccc solid 1px;
            margin: 100px auto;
            overflow: hidden;
        }
        div img{
            width: 300px;
            height: 300px;
            transition: all 0.5s ease 0s;
        }
        div img:hover{
            transform: scale(1.1);
        }

 

4. 案例:抽取奖金的效应:

 效果图  (素材可下载)

 背景

转盘

指针

 HTML代码:

    <div id="content">
        <div id="zhuan"></div>
        <img src="pointer.png" alt="图片 42">
    </div>

 css代码:

        #content {
            width: 698px;
            height: 674px;
            background: url('turntable-bg.jpg') no-repeat;
            margin: auto;
            overflow: hidden;
            position: relative;
        }

        #content #zhuan {
            width: 478px;
            height: 478px;
            background: url('turntable.png') no-repeat;
            margin: 97px 0 0 110px;
            transition: all 3s ease 0s;
        }

        #content img {
            position: absolute;
            left: 275px;
            top: 219px;
        }

JavaScript代码:

 1     <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
 2     <script>
 3         $(document).ready(function (e) {
 4             $('#content img').click(function (e) {
 5                 var num = Math.floor(Math.random() * 3600); //求的旋转的随机数
 6                 $('#zhuan').css('transform', 'rotate(' + num + 'deg)');//实际看到图片的旋转度数并没有在原来旋转的基础上累加,而是基于原来图片0度时的位置设置样式,图片不管在哪个位置都会以顺时针或逆时针旋转回基于原来0度+rotate(度)
 7                 num %= 360; //num = num % 360
 8                 setTimeout(function () {
 9                     if (num <= 60) {
10                         alert('谢谢参与');
11                     } else if (num <= 60*2) {
12                         alert('三等奖');
13                     } else if (num <= 60*3) {
14                         alert('谢谢参与');
15                     } else if (num <= 60*4) {
16                         alert('二等奖');
17                     } else if (num <= 60*5) {
18                         alert('谢谢参与');
19                     } else if(num < 60*6){
20                         alert('一等奖');
21                     }
22                 }, 3000);
23             });
24         });
25     </script>

 

      ps:一、要是急需开展多个转移, 那么用空格隔开

1. 渐变

          具体像素:transform-origin: 200px 0px;

4.1.7 CSS3 transform-origin 属性

transform-Origin属性允许你退换调换到分的职位。

二D调换成分得以更动成分的X和Y轴。 3D调换来分,还可以改形成分的Z轴。

为了更加好地通晓Transform-Origin属性,请查看那么些演示.

瞩目: 使用此属性必须先选择 transform 属性。

transform-origin: x-axis y-axis z-axis;

描述
x-axis 定义视图被置于 X 轴的何处。可能的值:left/center/right/length/%
y-axis 定义视图被置于 Y 轴的何处。可能的值:top/center/bottom/length/%
z-axis 定义视图被置于 Z 轴的何处。可能的值:length
    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #div1
    {
    position: relative;
    height: 200px;
    width: 200px;
    margin: 100px;
    padding:10px;
    border: 1px solid black;
    }

    #div2
    {
    padding:50px;
    position: absolute;
    border: 1px solid black;
    background-color: red;
    transform: rotate(45deg);
    transform-origin:20% 40%;
    -ms-transform: rotate(45deg); /* IE 9 */
    -ms-transform-origin:20% 40%; /* IE 9 */
    -webkit-transform: rotate(45deg); /* Safari and Chrome */
    -webkit-transform-origin:20% 40%; /* Safari and Chrome */
    }
    </style>
    </head>

    <body>

    <div id="div1">
      <div id="div2">HELLO</div>
    </div>

    </body>
    </html>

      3、缩放:第二个参数:水平方向,第三个参数:垂直方向,transform:
scale(0.5, 0.伍);transform: scale(1.伍);

今日科目预览

图片 43

这里写图片描述

图片 44

此地写图片描述

      编写套路:

倒影的表征:

  • 不占内容宽高
  • 倒影的层级比文书档案流的高
  • 倒影是相对标签进行倒影

    例如:场景一个div标签里面嵌套一个img标签;
    设置img图片标签的属性

    img{
        width: 100px;
    }
    设置div标签的属性
    div{

    <!-- 记得设置div浮动,为的是可以将块属性标签div当做一个行标签来使用,清浮动,而且默认宽度不是100%;-->
    float: left;
    <!--设置倒影-->     
    -webkit-box-reflect:left 0px -webkit-linear-gradient(left,rgba(0,0,0,.2) 30%,rgba(0,0,0,.6) 90%);

    }

展现效果如下图所示:

图片 45

倒影展现效果

示范代码:

4.1.1 translate() 方法

图片 46

translate()方法,依照左(X轴)和顶部(Y轴)地点给定的参数,从眼下因素地方移动。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:translate(50px,100px);
    -ms-transform:translate(50px,100px); /* IE 9 */
    -webkit-transform:translate(50px,100px); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

以身作则代码:

4.CSS3变形

    (二)过渡模块的其余性质:

4.1.8 transition补充

transition高级中学档也足以利用贝塞尔曲线。

例如:transition: all 1s cubic-bezier(0,0,0.8,1.8);

一般来讲图所示:

图片 47

  • CSS三贝塞尔曲线(cubic-bezier)参数详解

  • 留下的多少个特效:

  • ease: cubic-bezier(0.25, 0.1, 0.25, 1.0)

  • linear: cubic-bezier(0.0, 0.0, 1.0, 1.0)

  • ease-in: cubic-bezier(0.42, 0, 1.0, 1.0)

  • ease-out: cubic-bezier(0, 0, 0.58, 1.0)

  • ease-in-out: cubic-bezier(0.42, 0, 0.58, 1.0)

    先是,大家来学习多少个3D变形在这之中的多少个特性知识点;学习3D效果从前,大家来看一张三维空间图片,那是一张三个维度空间的基本图,分别有x轴、y轴、z轴多少个趋势;

    图片 48

3D平移 translate

3D平移分别有三个趋势:

率先个趋势:translateX(x) 定义 3D 转化,仅使用用于 X 轴的值,以X轴平移;

看下代码中所示,举例大家成立了贰个div标签(大家在div上加多壹行字,叫做”笔者是文字”,方便待会儿查看角度),然后设置其脾性为:

图片 49

图片 50

然后,大家来看一下3D运动,该现象下的运作效果(注意:首要看下鼠标滑到div上时的3个平移效果);

图片 51

  • 第四个方向:translateX(Y) 定义 3D 转化,仅使用用于 Y
    轴的值,以Y轴平移;那一个和以X轴方向大概,也正是前后运动,如若运动的负值,则往Y轴的负方向,也正是往下移动,反之,向上移动(这些位置就不做图解演示验证);

  • 其多个趋势:translateZ(z) 定义 3D 转化,仅使用用于 Z
    轴的值,以Z轴平移;对于那个角度的值,就得有三个维度空间的想象力了,那么,往Z周的正方一贯平移,也便是一定于与我们肉眼目视前方的相距越来越近;做个实例,大家来看一下;
    我们仍旧使用方面这么些曾经成立好的div标签,稍作修改,看下效果;

注意:在应用translateZ平移时,一定要定义三个透视点作为参照物以及开启3D视图;

图片 52

图片 53

图片 54

平等,我们来看一下3D活动,这一场所下的周转效果(注意:重要看下鼠标滑到div上时的多个离开大家特别近的位移效果
Z轴正方向);

图片 55

  • 3D旋转 rotate
  • rotateX(angle) 定义沿 X 轴的 3D 旋转。

1律,我们还是以上面这几个div为例,只要求将里面包车型的士transform部分修改为rotateX,沿X轴旋转;(只看修改代码的一些)

图片 56

图片 57

作者们来看下沿X轴旋转的功效;

图片 58

  • rotateY(angle) 定义沿 Y 轴的 3D
    旋转。(那么些只必要将地点代码中的rotateX修改为rotateY就可以,大家看下沿Y轴转动的效劳);

图片 59

  • rotateZ(angle) 定义沿 Z 轴的 3D
    旋转。(这一个只供给将方面代码中的rotateY修改为rotateZ就可以,大家看下沿Z轴旋转的法力)注意:Z轴的半空中是哪位角度;

图片 60

      壹、通过更动做好基本布局,如图:

4.1 2D 转换

珍惜行使上面八个格局:

  • translate()
  • rotate()
  • scale()
  • skew()
  • matrix()

新转变属性

以下列出了具备的调换属性:

Property 描述 CSS
transform 适用于2D或3D转换的元素 3
transform-origin 允许您更改转化元素位置 3

二D 转变方法

函数 描述
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 轴。

    (二)调换模块的形变中央点:

4.2 3D转换

CSS三 允许你使用 3D 调换成对成分举办格式化。

  • rotateX()
  • rotateY()

转变属性

下表列出了独具的更动属性:

属性 描述
transform 向元素应用 2D 或 3D 转换。
transform-origin 允许你改变被转换元素的位置。
transform-style 规定被嵌套元素如何在 3D 空间中显示。
perspective 规定 3D 元素的透视效果。
perspective-origin 规定 3D 元素的底部位置。
backface-visibility 定义元素在不面对屏幕时是否可见。

3D 转换方法

函数 描述
matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4×4 矩阵。
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 转换元素的透视视图。

图片 61 运动后

一.一 线性渐变

为了创制1个线性渐变,你必须至少定义两种颜色结点。颜色结点即你想要显示稳固对接的颜色。

还要,你也得以设置八个源点和2个主旋律(或3个角度)。

图片 62

语法:

background: linear-gradient(direction, color-stop1, color-stop2, ...);

线性渐变 – 从上到下(暗中同意景况下)

上边的实例演示了从顶部从头的线性渐变。源点是辛亥革命,逐步过渡到葡萄紫:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-linear-gradient(red, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(red, blue); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>线性渐变 - 从上到下</h3>
    <p>从顶部开始的线性渐变。起点是红色,慢慢过渡到蓝色:</p>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

线性渐变 – 从左到右

下边包车型客车实例演示了从左边开头的线性渐变。起源是革命,稳步过渡到石黄:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-linear-gradient(left, red , blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(right, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(right, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(to right, red , blue); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>线性渐变 - 从左到右</h3>
    <p>从左边开始的线性渐变。起点是红色,慢慢过渡到蓝色:</p>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

线性渐变 – 对角

您能够经过点名水平和垂直的前奏地方来塑造二个对角渐变。

下边包车型客车实例演示了从左上角先河(到右下角)的线性渐变。源点是新民主主义革命,稳步过渡到青蓝:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-linear-gradient(left top, red , blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(bottom right, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(bottom right, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(to bottom right, red , blue); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>线性渐变 - 对角</h3>
    <p>从左上角开始(到右下角)的线性渐变。起点是红色,慢慢过渡到蓝色:</p>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

应用角度

比如您想要在潜移默化的大势上做越来越多的决定,你能够定义八个角度,

而不用预订义方向(to bottom、to top、to right、to left、to bottom
right,等等)。

语法

background: linear-gradient(angle, color-stop1, color-stop2);

角度是指水平线和渐变线之间的角度,逆时针方向总括。

换句话说,0deg 将创立三个从下到上的渐变,90deg
将开创多个从左到右的渐变。

图片 63

然而,请留意繁多浏览器(Chrome,Safari,fiefox等)的施用了旧的正规,

即 0deg 将创立2个从左到右的渐变,90deg 将成立一个从下到上的渐变。

换算公式 90 – x = y 当中 x 为正规角度,y为非规范角度。

上面包车型地铁实例演示了哪些在线性渐变上使用角度:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 100px;
        background: -webkit-linear-gradient(0deg, red, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(0deg, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(0deg, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(0deg, red, blue); /* 标准的语法(必须放在最后) */
    }

    #grad2 {
        height: 100px;
        background: -webkit-linear-gradient(90deg, red, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(90deg, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(90deg, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(90deg, red, blue); /* 标准的语法(必须放在最后) */
    }

    #grad3 {
        height: 100px;
        background: -webkit-linear-gradient(180deg, red, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(180deg, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(180deg, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(180deg, red, blue); /* 标准的语法(必须放在最后) */
    }

    #grad4 {
        height: 100px;
        background: -webkit-linear-gradient(-90deg, red, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(-90deg, red, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(-90deg, red, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(-90deg, red, blue); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>线性渐变 - 使用不同的角度</h3>
    <div id="grad1" style="color:white;text-align:center;">0deg</div><br>
    <div id="grad2" style="color:white;text-align:center;">90deg</div><br>
    <div id="grad3" style="color:white;text-align:center;">180deg</div><br>
    <div id="grad4" style="color:white;text-align:center;">-90deg</div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

应用八个颜色结点

上边包车型客车实例演示了什么设置两个颜色结点:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-linear-gradient(red, green, blue); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(red, green, blue); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(red, green, blue); /* Firefox 3.6 - 15 */
        background: linear-gradient(red, green, blue); /* 标准的语法(必须放在最后) */
    }

    #grad2 {
        height: 200px;
        background: -webkit-linear-gradient(red, orange, yellow, green, blue, indigo, violet); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(red, orange, yellow, green, blue, indigo, violet); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(red, orange, yellow, green, blue, indigo, violet); /* Firefox 3.6 - 15 */
        background: linear-gradient(red, orange, yellow, green, blue, indigo, violet); /* 标准的语法(必须放在最后) */
    }

    #grad3 {
        height: 200px;
        background: -webkit-linear-gradient(red 10%, green 85%, blue 90%); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(red 10%, green 85%, blue 90%); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(red 10%, green 85%, blue 90%); /* Firefox 3.6 - 15 */
        background: linear-gradient(red 10%, green 85%, blue 90%); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>3 个颜色结点(均匀分布)</h3>
    <div id="grad1"></div>

    <h3>7 个颜色结点(均匀分布)</h3>
    <div id="grad2"></div>

    <h3>3 个颜色结点(不均匀分布)</h3>
    <div id="grad3"></div>

    <p><strong>注意:</strong> 当未指定百分比时,颜色结点不会自动均匀分布。</p>
    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

下边包车型客车实例演示了什么样创设3个涵盖彩虹颜色和文件的线性渐变:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 55px;
        background: -webkit-linear-gradient(left, red, orange, yellow, green, blue, indigo, violet); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(left, red, orange, yellow, green, blue, indigo, violet); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(left, red, orange, yellow, green, blue, indigo, violet); /* Firefox 3.6 - 15 */
        background: linear-gradient(to right, red, orange, yellow, green, blue, indigo, violet); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <div id="grad1" style="text-align:center;margin:auto;color:#888888;font-size:40px;font-weight:bold">
    渐变背景
    </div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

利用光滑度(Transparency)

CSS三 渐变也支撑反射率(transparency),可用以成立减少变淡的作用。

为了充分光滑度,大家采取 rgba() 函数来定义颜色结点。

rgba() 函数中的最终多个参数能够是从 0 到 一 的值,它定义了颜色的发光度:

0 表示完全透明,一 代表完全不透明。

上边的实例演示了从右边发轫的线性渐变。起点是一点1滴透明,逐步过渡到完全不透明的辛丑革命:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-linear-gradient(left, rgba(255,0,0,0), rgba(255,0,0,1)); /* Safari 5.1 - 6.0 */
        background: -o-linear-gradient(right, rgba(255,0,0,0), rgba(255,0,0,1)); /* Opera 11.1 - 12.0 */
        background: -moz-linear-gradient(right, rgba(255,0,0,0), rgba(255,0,0,1)); /* Firefox 3.6 - 15 */
        background: linear-gradient(to right, rgba(255,0,0,0), rgba(255,0,0,1)); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>线性渐变 - 透明度</h3>
    <p>为了添加透明度,我们使用 rgba() 函数来定义颜色结点。rgba() 函数中的最后一个参数可以是从 0 到 1 的值,它定义了颜色的透明度:0 表示完全透明,1 表示完全不透明。</p>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

再次的线性渐变

repeating-linear-gradient() 函数用于重复线性渐变:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 200px;
        background: -webkit-repeating-linear-gradient(red, yellow 10%, green 20%); /* Safari 5.1 - 6.0 */
        background: -o-repeating-linear-gradient(red, yellow 10%, green 20%); /* Opera 11.1 - 12.0 */
        background: -moz-repeating-linear-gradient(red, yellow 10%, green 20%); /* Firefox 3.6 - 15 */
        background: repeating-linear-gradient(red, yellow 10%, green 20%); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>重复的线性渐变</h3>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

      rotate旋转属性旋转是暗中认可都以围绕z轴旋转,若必要改动旋转轴能够在rotate后增加旋转轴,即:rotateX();rotateY();rotateZ();

4.2.1 rotateX() 方法

图片 64

rotateX()方法,围绕其在一个给定度数X轴旋转的因素。

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:75px;
    background-color:red;
    border:1px solid black;
    }
    div#div2
    {
    transform:rotateX(120deg);
    -webkit-transform:rotateX(120deg); /* Safari and Chrome */
    }
    </style>
    </head>
    <body>

    <p><b>Note:</b> Internet Explorer 9 (and earlier versions) and Opera does not support the rotateX method.</p>

    <div>Hello. This is a DIV element.</div>

    <div id="div2">Hello. This is a DIV element.</div>

    </body>
    </html>

      过渡连写注意点
        一和分手写一样,
尽管想给四个个性增加过渡效果也是用逗号隔离就可以
        2连写的时得以大概前边的三个参数,
因为只要编写了前边的四个参数就已经满足了连接的三要素
        三比方四个性情运动的快慢/延迟的小运/持续时间都1致,
那么能够简写为:transition:all 0s;

一.2 CSS三 径向渐变

通向渐变由它的骨干概念。

为了创设一个通往渐变,你也亟须至少定义二种颜色结点。颜色结点即你想要突显平稳对接的颜色。

同时,你也得以钦赐渐变的中坚、形状(原型或纺锤形)、大小。

私下认可情形下,渐变的为主是 center(表示在中央点),渐变的形态是
ellipse(表示长方形),

潜移默化的轻重是 farthest-corner(表示到最远的犄角)。

向阳渐变的实例:

图片 65

background: radial-gradient(center, shape size, start-color, ..., last-color);

通向渐变 – 颜色结点均匀布满(私下认可情状下)

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 150px;
        width: 200px;
        background: -webkit-radial-gradient(red, green, blue); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(red, green, blue); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(red, green, blue); /* Firefox 3.6 - 15 */
        background: radial-gradient(red, green, blue); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>径向渐变 - 颜色结点均匀分布</h3>
    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

通向渐变 – 颜色结点不均匀遍及

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 150px;
        width: 200px;
        background: -webkit-radial-gradient(red 5%, green 15%, blue 60%); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(red 5%, green 15%, blue 60%); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(red 5%, green 15%, blue 60%); /* Firefox 3.6 - 15 */
        background: radial-gradient(red 5%, green 15%, blue 60%); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>径向渐变 - 颜色结点不均匀分布</h3>
    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

安装形状

shape 参数定义了造型。

它能够是值 circle 或 ellipse。在那之中,circle 代表圆形,ellipse
代表纺锤形。

暗中认可值是 ellipse。

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 150px;
        width: 200px;
        background: -webkit-radial-gradient(red, yellow, green); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(red, yellow, green); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(red, yellow, green); /* Firefox 3.6 - 15 */
        background: radial-gradient(red, yellow, green); /* 标准的语法(必须放在最后) */
    }

    #grad2 {
        height: 150px;
        width: 200px;
        background: -webkit-radial-gradient(circle, red, yellow, green); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(circle, red, yellow, green); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(circle, red, yellow, green); /* Firefox 3.6 - 15 */
        background: radial-gradient(circle, red, yellow, green); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>径向渐变 - 形状</h3>

    <p><strong>椭圆形 Ellipse(默认):</strong></p>
    <div id="grad1"></div>

    <p><strong>圆形 Circle:</strong></p>
    <div id="grad2"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

今非昔比尺寸大小关键字的运用

size 参数定义了渐变的分寸。它能够是以下四个值:

  • closest-side
  • farthest-side
  • closest-corner
  • farthest-corner

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 150px;
        width: 150px;
        background: -webkit-radial-gradient(60% 55%, closest-side,blue,green,yellow,black); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(60% 55%, closest-side,blue,green,yellow,black); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(60% 55%, closest-side,blue,green,yellow,black); /* Firefox 3.6 - 15 */
        background: radial-gradient(60% 55%, closest-side,blue,green,yellow,black); /* 标准的语法(必须放在最后) */
    }

    #grad2 {
        height: 150px;
        width: 150px;
        background: -webkit-radial-gradient(60% 55%, farthest-side,blue,green,yellow,black); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(60% 55%, farthest-side,blue,green,yellow,black); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(60% 55%, farthest-side,blue,green,yellow,black); /* Firefox 3.6 - 15 */
        background: radial-gradient(60% 55%, farthest-side,blue,green,yellow,black); /* 标准的语法(必须放在最后) */
    }

    #grad3 {
        height: 150px;
        width: 150px;
        background: -webkit-radial-gradient(60% 55%, closest-corner,blue,green,yellow,black); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(60% 55%, closest-corner,blue,green,yellow,black); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(60% 55%, closest-corner,blue,green,yellow,black); /* Firefox 3.6 - 15 */
        background: radial-gradient(60% 55%, closest-corner,blue,green,yellow,black); /* 标准的语法(必须放在最后) */
    }

    #grad4 {
        height: 150px;
        width: 150px;
        background: -webkit-radial-gradient(60% 55%, farthest-corner,blue,green,yellow,black); /* Safari 5.1 - 6.0 */
        background: -o-radial-gradient(60% 55%, farthest-corner,blue,green,yellow,black); /* Opera 11.6 - 12.0 */
        background: -moz-radial-gradient(60% 55%, farthest-corner,blue,green,yellow,black); /* Firefox 3.6 - 15 */
        background: radial-gradient(60% 55%, farthest-corner,blue,green,yellow,black); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>径向渐变 - 不同尺寸大小关键字的使用</h3>

    <p><strong>closest-side:</strong></p>
    <div id="grad1"></div>

    <p><strong>farthest-side:</strong></p>
    <div id="grad2"></div>

    <p><strong>closest-corner:</strong></p>
    <div id="grad3"></div>

    <p><strong>farthest-corner(默认):</strong></p>
    <div id="grad4"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

重新的通向渐变

repeating-radial-gradient() 函数用于重复径向渐变:

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    #grad1 {
        height: 150px;
        width: 200px;
        background: -webkit-repeating-radial-gradient(red, yellow 10%, green 15%); /* Safari 5.1 - 6.0 */
        background: -o-repeating-radial-gradient(red, yellow 10%, green 15%); /* Opera 11.6 - 12.0 */
        background: -moz-repeating-radial-gradient(red, yellow 10%, green 15%); /* Firefox 3.6 - 15 */
        background: repeating-radial-gradient(red, yellow 10%, green 15%); /* 标准的语法(必须放在最后) */
    }
    </style>
    </head>
    <body>

    <h3>重复的径向渐变</h3>

    <div id="grad1"></div>

    <p><strong>注意:</strong> Internet Explorer 9 及之前的版本不支持渐变。</p>

    </body>
    </html>

示范代码:

        2、思虑怎么得以落成要做的效果,和急需改动的属性

      暗中同意情形下具有的成分都以以温馨的主干点作为参考来旋转的,
大家得以因此形变大旨点属性来修改它的参考场。  

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图