过渡效果和变形详细图示

过渡效果(transition)

在css3中发布了三种新添加的特性,可以让静止的网站变得动起来,而且不需要借助js脚本就能实现。
这便是其中的一种,过渡。

transition-duration

transition-duration 属性规定完成过渡效果需要花费的时间。

    <style>
        div {
            width: 100px;
            height: 100px;
            background: lightblue;
            transition-property: width;
            transition-duration: 5s;
        }

        div:hover {
            width: 333px;
        }
    </style>
<body>
    <div></div>
    <p>将鼠标移动至块上即可看到过渡动画效果.</p>
    <p><b>注意:</b> 该过渡效果会持续5s.</p>
</body>

过渡经常和:hover一起使用,效果为:
在这里插入图片描述

transition-property

transition-property 属性规定应用过渡效果的 CSS 属性的名称。

<style>
    div
    {
        width:100px;
        height:100px;
        background:green;
        transition-duration:3s;
       
        transition-property:width,height,background-color;
    }
    div:hover
    {
        width:333px;
        height: 222px;
        background-color: #2ebb96;
    }
</style>
<body>
   <div></div>
   <p>将鼠标移动至块上即可看到过渡动画效果.</p>
   <p><b>注意:</b> 该过渡效果会持续3s.指定的width,height,background-color会发生改变</p>
</body>

效果为
在这里插入图片描述

transition-delay

transition-delay 属性指定何时将开始切换效果。

<style>
    div
    {
        width:100px;
        height:100px;
        background:green;
        transition-duration:3s;
        transition-property:width,height,background-color;
        transition-delay: 1s;
    }
    div:hover
    {
        width:333px;
        height: 222px;
        background-color: #2ebb96;
    }
</style>
<body>
   <div></div>
   <p>将鼠标移动至块上即可看到过渡动画效果.</p>
   <p><b>注意:</b> 该过渡效果会持续3s.指定的width,height,background-color会发生改变</p>
</body>

效果为
在这里插入图片描述

transition-timing-function

transition-timing-function属性指定切换效果的速度。
该属性使用贝塞尔曲线来设置,css提供了一些特定的效果,当然也可以自己自定义贝塞尔曲线函数。

  1. linear: 线性过渡。等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0)
  2. ease:默认值,平滑过渡。等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0)
  3. ease-in:由慢到快。等同于贝塞尔曲线(0.42, 0, 1.0, 1.0)
  4. ease-out: 由快到慢。等同于贝塞尔曲线(0, 0,0.58, 1.0)
  5. ease-in-out: 由慢到快再到慢。等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)
  6. cubic-bezier(, , , ):特定的贝塞尔曲线类型,4个数值需在[0, 1]区间内
    在这里插入图片描述
    然后我自定义了一个贝塞尔曲线cubic-bezier(0.71,1.8,1,-0.74);
    在这里插入图片描述
<style>
    div
    {
        width:100px;
        height:50px;
        background:green;
        color:white;
        font-weight:bold;
        transition:width 3s;
        margin-bottom: 10px;
    }

    #div1 {transition-timing-function: linear;}
    #div2 {transition-timing-function: ease;}
    #div3 {transition-timing-function: ease-in;}
    #div4 {transition-timing-function: ease-out;}
    #div5 {transition-timing-function: ease-in-out;}
    #div6 {transition-timing-function: cubic-bezier(0.71,1.8,1,-0.74);}
    div:hover
    {
        width:333px;
    }
</style>
<body>
    <p>将鼠标移至相应块上即可查看过渡动画.</p>
    <div id="div1" style="top:100px">linear</div>
    <div id="div2" style="top:150px">ease</div>
    <div id="div3" style="top:200px">ease-in</div>
    <div id="div4" style="top:250px">ease-out</div>
    <div id="div5" style="top:300px">ease-in-out</div>
    <div id="div6" style="top:300px">我的自定义</div>
</body>

效果:
在这里插入图片描述

transition

transition同样可以缩小

transition:[ transition-property ] || [ transition-duration ] ||
 [ transition-timing-function ] || [ transition-delay ];

变形(transition)

transform属性应用于元素的2D或3D转换。
指定相应的变形函数就能达到相应的效果。

旋转函数rotate

rotate(angle):旋转,参数angle表示要旋转的角度值。如果角度为正数值,则按照顺时针进行旋转, 否则,按照逆时针旋转。

  • rotate(angle) 定义 2D 旋转,在参数中规定角度。
  • rotateX(angle) 定义沿着 X 轴的 3D 旋转。
  • rotateY(angle) 定义沿着 Y 轴的 3D 旋转。
  • rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。
  • rotate3d(x,y,z,angle) 定义 3D 旋转。
 <style>
        div
        {
            display: inline-block;
            margin: 30px;
            font-size: 14px;
            text-align: center;
            line-height: 150px;
            width:150px;
            height:150px;
            background:lightskyblue;
            color:white;
            transition:all 3s;
            margin-bottom: 10px;
        }

        #div1:hover {transform: rotate(360deg);}
        #div2:hover {transform: rotate(-360deg);}
        #div3:hover {transform: rotateX(360deg);}
        #div4:hover {transform: rotateY(360deg);}
        #div5:hover {transform: rotateZ(360deg);}
        #div6:hover {transform: rotate3D(1,1,1,180deg);}
        
    </style>
<body>
    <p>将鼠标移至相应块上即可查看过渡动画.</p>
    <p>这是2D的旋转</p>
    <div id="div1" >rotate(360deg)</div>
    <div id="div2" >rotate(-360deg)</div>
    <br>
    <p>这是3D的旋转</p>
    <div id="div3" >rotateX(360deg)</div>
    <div id="div4" >rotateY(360deg)</div>
    <div id="div5" >rotateZ(360deg)</div>
    <div id="div6" >rotate3D(1,1,1,180deg)</div>
</body>

为了效果上的直观,所以添加了过渡属性,让方块的改变更加清晰。
效果为:
在这里插入图片描述

移动translate

  • translate(x,y) 定义 2D 转换。
  • translateX(x) 定义转换,只是用 X 轴的值。
  • translateY(y) 定义转换,只是用 Y 轴的值。
  • translateZ(z) 定义 3D 转换,只是用 Z 轴的值。
  • translate3d(x,y,z) 定义 3D 转换。

这是2D的移动

<style>
    div
    {
        display: inline-block;
        margin: 30px;
        font-size: 14px;
        text-align: center;
        line-height: 150px;
        width:150px;
        height:150px;
        background:lightskyblue;
        color:white;
        transition:all 3s;
        margin-bottom: 10px;
    }

    #div1:hover {transform: translateX(200px);}
    #div2:hover {transform: translateY(200px);}
    #div3:hover {transform: translate(200px,200px);}
    
</style>
<body>
    <p>将鼠标移至相应块上即可查看过渡动画.</p>
    <p>这是2D的移动</p>
    <div id="div1" >X轴移动:translateX</div>
    <div id="div2" >Y轴移动:translateY</div>
    <br>
    <div id="div3" >XY轴移动:translate</div>
    <br>
</body>

效果为:
在这里插入图片描述

缩放scale

  • scaleX(x) 通过设置 X 轴的值来定义缩放转换。
  • scaleY(y) 通过设置 Y 轴的值来定义缩放转换。
  • scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。
  • scale(x[,y]?) 定义 2D 缩放转换。
  • scale3d(x,y,z) 定义 3D 缩放转换。
    2D方向的缩放
<style>
    div
    {
        display: inline-block;
        margin: 30px;
        font-size: 14px;
        text-align: center;
        line-height: 150px;
        width:150px;
        height:150px;
        background:lightskyblue;
        color:white;
        transition:all 3s;
        margin-bottom: 10px;
        margin-left: 50px;
    }

    #div1:hover {transform: scaleX(1.5);}
    #div2:hover {transform: scaleY(0.5);}
    #div3:hover {transform: scale(1.5,.5);}
</style>
<body>
    <p>将鼠标移至相应块上即可查看过渡动画.</p>
    <p>这是2D的缩放</p>
    <div id="div1" >X轴放大:scaleX(1.5)</div>
    <div id="div2" >Y轴缩小:scaleY(0.5)</div>
    <br>
    <div id="div3" >XY轴缩放:scale(1.5,.5)</div>
</body>

效果为:
在这里插入图片描述

倾斜skew

  • skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。
  • skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。
  • skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。
 <style>
     div
     {
         display: inline-block;
         margin: 30px;
         font-size: 14px;
         text-align: center;
         line-height: 150px;
         width:150px;
         height:150px;
         background:lightskyblue;
         color:white;
         transition:all 3s;
         margin-bottom: 10px;
         margin-left: 50px;
     }

     #div1:hover {transform: skewX(45deg);}
     #div2:hover {transform: skewY(45deg);}
     #div3:hover {transform: skew(15deg,30deg);}
     
 </style>
<body>
    <p>将鼠标移至相应块上即可查看过渡动画.</p>
    <p>这是2D的缩放</p>
    <div id="div1" >X轴倾斜45度:skewX(45deg)</div>
    <div id="div2" >Y轴倾斜45度:skewY(45deg)</div>
    <br>
    <div id="div3" >XY轴倾斜:skew(15deg,30deg)</div>
</body>

效果为:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值