popup

随机跳出大小颜色不一样的div。
实现后的效果如下
这里写图片描述
以下是基本布局的代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>popupBall</title>
</head>
<body>
<div id="box">
</div>

提前写一下基本的样式

<style>
        #box {
            width: 555px;
            height: 555px;
            background: #e4393c;
            position: relative;
        }
        #box div {
            position: absolute;
        }
    </style>

下来就是要写js脚本,首先定义全局变量box,num,其中num用来记录div的数量;

 window.onload = function () {
        var box = document.getElementById("box");
        var num = 1;
  }

准备一个生成随机数的函数

function randomN(min, max) {
            return Math.floor(Math.random() * (max - min) + min)
        }

一个生成随机颜色的函数

function randomColor() {
            return '#' +
                (function (color) {
                    return (color += '0123456789abcdef'[Math.floor(Math.random() * 16)]) && (color.length == 6) ? color : arguments.callee(color);
                })('');
        }

一个生成随机div的函数

function newDiv() {
            var doc = document;
            box.appendChild(doc.createDocumentFragment().appendChild(doc.createElement("div")));
            var that = doc.querySelector("#box>div:last-child");
            that.style.width = randomN(5, 50) + "px";
            that.style.height = randomN(5, 50) + "px";
            that.style.borderRadius = randomN(5, 50);
            that.style.top = randomN(30, 500) + "px";
            that.style.left = randomN(30, 500) + "px";
            that.style.backgroundColor = randomColor();
            that.style.borderRadius = randomN(5, 50) + "%";
            num++;
        }

一个删除随机某个div的函数

function removeDiv() {
            var doc = document;
            var child = "#box>div:nth-child(" + randomN(1, num) + ")";
            if (child) {
                var del = doc.querySelector(child);
                box.removeChild(del);
                num--;
            }
        }

如何启动呢?给box添加一个点击开始的函数

 box.onclick = function(){}

在这个函数里面,加一个定时器,定时器内部利用num进行判断,只要num小于10,就只添加。。。。

box.onclick = function () {
            setInterval(function () {
                if (num < 10) {
                    newDiv();
                    newDiv();
                    newDiv();
                    newDiv();
                    newDiv();
                    newDiv();
                    newDiv();
                    newDiv();
                }
                if (num > 50) {
                    removeDiv();
                    newDiv();
                    removeDiv();
                    newDiv();
                    removeDiv();
                    removeDiv();
                    newDiv();
                    removeDiv();
                    newDiv();
                    removeDiv();
                }
                else {
                    newDiv();
                    removeDiv();
                    newDiv();
                    removeDiv();
                    newDiv();
                    newDiv();
                    removeDiv();
                    newDiv();
                    removeDiv();
                    newDiv();
                }
            }, 100)
        }

这样就完成了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

liugang0605

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值