• CSS3 @keyframes 规则


    @keyframes 是实现过渡动画的方式。在动画过程中,通过更改css样式,实现从一个CSS样式设定到另一个。

    定义和用法

    通过 @keyframes 规则,您能够创建动画。

    创建动画的原理是,将一套 CSS 样式逐渐变化为另一套样式。

    在动画过程中,您能够多次改变这套 CSS 样式。

    以百分比来规定改变发生的时间,或者通过关键词 "from" 和 "to",等价于 0% 和 100%。

    0% 是动画的开始时间,100% 动画的结束时间。

    为了获得最佳的浏览器支持,您应该始终定义 0% 和 100% 选择器。

    注释:请使用动画属性来控制动画的外观,同时将动画与选择器绑定。

    语法

    @keyframes animationname {keyframes-selector {css-styles;}}
    说明
    animationname 必需的。定义animation的名称。
    keyframes-selector 必需的。动画持续时间的百分比。

    合法值:

    0-100%
    from (和0%相同)
    to (和100%相同)

    注意: 您可以用一个动画keyframes-selectors。

    css-styles 必需的。一个或多个合法的CSS样式属性

    浏览器支持

    IE10以上支持 @keyframes 规则。

    Firefox 支持替代的 @-moz-keyframes 规则。

    Opera 支持替代的 @-o-keyframes 规则。

    Safari 和 Chrome 支持替代的 @-webkit-keyframes 规则。

    实例

    1、使一个div元素逐渐移动200像素:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8"> 
    <title>菜鸟教程(runoob.com)</title> 
    <style> 
    div
    {
        width:100px;
        height:100px;
        background:red;
        position:relative;
        animation:mymove 5s infinite;
        -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
    }
    
    @keyframes mymove
    {
        from {top:0px;}
        to {top:200px;}
    }
    
    @-webkit-keyframes mymove /* Safari and Chrome */
    {
        from {top:0px;}
        to {top:200px;}
    }
    </style>
    </head>
    <body>
    
    <p>注意:  @keyframes 规则 不兼容 IE 9 以及更早版本的浏览器.</p>
    <div></div>
    
    </body>
    </html>

    2、在一个动画中添加多个 keyframe 选择器:

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:100px;
    background:red;
    position:relative;
    animation:mymove 5s infinite;
    -moz-animation:mymove 5s infinite; /* Firefox */
    -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
    -o-animation:mymove 5s infinite; /* Opera */
    }
    
    @keyframes mymove
    {
    0%   {top:0px;}
    25%  {top:200px;}
    75%  {top:50px}
    100% {top:100px;}
    }
    
    @-moz-keyframes mymove /* Firefox */
    {
    0%   {top:0px;}
    25%  {top:200px;}
    75%  {top:50px}
    100% {top:100px;}
    }
    
    @-webkit-keyframes mymove /* Safari and Chrome */
    {
    0%   {top:0px;}
    25%  {top:200px;}
    75%  {top:50px}
    100% {top:100px;}
    }
    
    @-o-keyframes mymove /* Opera */
    {
    0%   {top:0px;}
    25%  {top:200px;}
    75%  {top:50px}
    100% {top:100px;}
    }
    </style>
    </head>
    <body>
    
    <p>注释:本例不兼容 IE 9 以及更早版本的浏览器。</p>
    <div></div>
    
    </body>
    </html>

    3、在一个动画中改变多个 CSS 样式:

    <!DOCTYPE html>
    <html>
    <head>
    <style> 
    div
    {
    width:100px;
    height:100px;
    background:red;
    position:relative;
    animation:mymove 5s infinite;
    -moz-animation:mymove 5s infinite; /* Firefox */
    -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
    -o-animation:mymove 5s infinite; /* Opera */
    }
    
    @keyframes mymove
    {
    0%   {top:0px; background:red; width:100px;}
    100% {top:200px; background:yellow; width:300px;}
    }
    
    @-moz-keyframes mymove /* Firefox */
    {
    0%   {top:0px; background:red; width:100px;}
    100% {top:200px; background:yellow; width:300px;}
    }
    
    @-webkit-keyframes mymove /* Safari and Chrome */
    {
    0%   {top:0px; background:red; width:100px;}
    100% {top:200px; background:yellow; width:300px;}
    }
    
    @-o-keyframes mymove /* Opera */
    {
    0%   {top:0px; background:red; width:100px;}
    100% {top:200px; background:yellow; width:300px;}
    }
    </style>
    </head>
    <body>
    
    <p>注释:本例不兼容 IE 9 以及更早版本的浏览器</p>
    
    <div></div>
    
    </body>
    </html>

    4、带有多个 CSS 样式的多个 keyframe 选择器:

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8"> 
    <title>菜鸟教程(runoob.com)</title>
    <style> 
    div
    {
        width:100px;
        height:100px;
        background:red;
        position:relative;
        animation:mymove 5s infinite;
        -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
    }
    
    @keyframes mymove
    {
        0%   {top:0px; left:0px; background:red;}
        25%  {top:0px; left:100px; background:blue;}
        50%  {top:100px; left:100px; background:yellow;}
        75%  {top:100px; left:0px; background:green;}
        100% {top:0px; left:0px; background:red;}
    }
    
    @-webkit-keyframes mymove /* Safari and Chrome */
    {
        0%   {top:0px; left:0px; background:red;}
        25%  {top:0px; left:100px; background:blue;}
        50%  {top:100px; left:100px; background:yellow;}
        75%  {top:100px; left:0px; background:green;}
        100% {top:0px; left:0px; background:red;}
    }
    </style>
    </head>
    <body>
    
    <p>注意: @keyframes不兼容IE 9 and 以及更早版本的浏览器.</p>
    
    <div></div>
    
    </body>
    </html>

     

  • 相关阅读:
    前端构建工具gulp使用
    网页部分内容显示不全
    less简单入门
    jquery——移动端滚动条插件iScroll.js
    css3常用动画+动画库
    windows下nodejs环境配置
    jquery——滚动条插件jscroll.js
    工欲善其事必先利其器——dreamweaver
    jquery常用方法
    nodejs模块——http模块
  • 原文地址:https://www.cnblogs.com/joe235/p/13437861.html
Copyright © 2020-2023  润新知