zoukankan      html  css  js  c++  java
  • 【CSS3 + 原生JS】上升的方块动态背景

    GIF图有点大,网速慢的或将稍等片刻或可浏览本人的制作的demo。

    Demo : 点击查看

    HTML:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Glunefish</title>
        <link rel="stylesheet" href="css/style.css">
    </head>
    <body>
        <div id="F-dynamicbg-box">
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
            <div></div>
        </div>
    </body>
    </html>

    CSS:

        * {
            margin: 0; padding: 0; border: none; outline: 0; 
        }
        body{
            width: 100vw;
            height: 100vh;
            background: url(img/bg.png) no-repeat;
            background-size: cover;
        }
        #F-dynamicbg-box {
            width: 100vw;
            height: 100vh;
            position: absolute;
            top: 0;
            left: 0;
            overflow: hidden;
        }
        #F-dynamicbg-box > div {
            z-index: -9999;
            background-color: rgba(255,255,255,.1);
            position: absolute;
            top: 105vh;
            animation: dynamicDiv 30s linear infinite;
        }
        #F-dynamicbg-box > div:nth-of-type(1) { animation-delay: 1s }
        #F-dynamicbg-box > div:nth-of-type(2) { animation-delay: 3s }
        #F-dynamicbg-box > div:nth-of-type(3) { animation-delay: 6s }
        #F-dynamicbg-box > div:nth-of-type(4) { animation-delay: 9s }
        #F-dynamicbg-box > div:nth-of-type(5) { animation-delay: 12s }
        #F-dynamicbg-box > div:nth-of-type(6) { animation-delay: 4s }
        #F-dynamicbg-box > div:nth-of-type(7) { animation-delay: 15s }
        #F-dynamicbg-box > div:nth-of-type(8) { animation-delay: 18s }
        #F-dynamicbg-box > div:nth-of-type(9) { animation-delay: 20s }
        #F-dynamicbg-box > div:nth-of-type(10) { animation-delay: 16s }
    
    
        @keyframes dynamicDiv {
            form { top: 105vh; transform: scale(1.2); }
            to { top: -13vh; transform: scale(1) rotate(60deg); }
        }
    

    JS:( JS初始化div形态 )

            var box = document.getElementById('F-dynamicbg-box'),
                div = box.getElementsByTagName('div'),
                math = [0,1];for (var i=0;i<div.length;i++) {
                    math[1] = F_getSJS(100,40,9)                          F_getSJS 请移步博客之前的取随机数了解 
                    if(math[1] != math[2]){
                        div[i].style.width = math[1] + 'px';
                        div[i].style.height = math[1] + 'px';
                        math[2] = math[1];
                    }
                }
    
                for(var i=0;i<div.length;i++){
                    div[i].style.left = F_getSJS(85,15,8) + 'vw';
                    div[i].style.transform = 'rotate(' + F_getSJS(360,5,9) + 'deg)';
                }
    转载请指明出处!
  • 相关阅读:
    vue本地项目静态资源管理
    vue-resource的使用
    查看Python已安装的模块
    getpass密码输入模块
    css之浮动
    Linux之常用命令和部分解析
    css之vertical-align(盒子垂直对齐方式)
    Octave 里的 fminunc
    Octave /Matlab--Control Statements:for,while, if statement----Coursera ML笔记
    Octave环境的安装
  • 原文地址:https://www.cnblogs.com/GruntFish/p/6901667.html
Copyright © 2011-2022 走看看