1. 程式人生 > >JavaScript例項 躁動的小球

JavaScript例項 躁動的小球


<!doctype html>

<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style type="text/css">
        html,body{
            margin: 0;
                 padding: 0;
            width: 100%;
            height: 100%;
            background: #000;
            overflow: hidden;
            position: absolute;
        }
        div{
            position: absolute;
            border-radius: 50%;
        }
    </style>

</head>
<body>
 <script type="text/javascript">
    var d1=document.getElementById('d1')
    function Ball(obj){
        this._init(obj);
    }
        Ball.prototype={
            // 初始化
            _init:function(obj){

                // 獲取父節點

                this.parentnode=obj.parentNode;
                this.div=document.createElement('div');
                this.r=ranDom(10,70);
                this.x=ranDom(0,1200);

                this.y=ranDom(0,500);

                // 小球背景顏色的設定

                this.color=`rgba(${ranDom(0,255)},${ranDom(0,255)},${ranDom(0,255)},${Math.random()*0.6+0.4})`;       //設定透明度

                // 小球速度設定
                this.speedX=ranDom(-10,20);
                this.speedY=ranDom(-10,20);

            },

            // 顯示小球
            show:function(){
                var div=this.div;
                div.style.width=this.r*2+"px";                   //注意這些地方的px一定要加上去   因為CSS的樣式為字串型別 所以要+上“px”;
                div.style.height=this.r*2+"px";
                div.style.background=this.color;
                div.style.left=this.x+"px";
                div.style.top=this.y+"px";
                this.parentnode.appendChild(div);

            },

            // 設定移動
            roll:function(){
                var div=this.div;
                var i=1;
                var j=1;
                var speedX=this.speedX;
                var speedY=this.speedY;
                var maxLeft=this.parentnode.offsetWidth-div.offsetWidth;

                var maxTop=this.parentnode.offsetHeight-div.offsetHeight;

                // 定時器
                setTimeout(function loop(){
                    if(div.offsetLeft>maxLeft|| div.offsetLeft<0){
                        i*=-1;
                    }
                    if(div.offsetTop>maxTop|| div.offsetTop<0){
                        j*=-1;
                    }
                    div.style.left=div.offsetLeft+i*speedX+"px";
                    div.style.top=div.offsetTop+j*speedY+"px";
                    setTimeout(loop,20);
                },20);
            },

        }

        // 設定小球的個數
    for(var i=0;i<20;i++){
        var b2= new Ball({parentNode:document.body});
        b2.show();
        b2.roll();

    }

    // 隨機數
    function ranDom(small,big){
        return parseInt(Math.random()*(big-small+1)+small);
    }
    </script>
</body>
</html>