如何用ES6新属性写“躁动的小球”

       提到“躁动的小球”对于前端爱好者来说并不陌生,其书写的方式有很多种,其核心思想不过为针对浏览器的left和top值、定时器控制物体多长时间移动多长距离,怎么移动,多大的物体等等...
       为了防止低版本浏览器版本兼容性差,所以我也准备了两个版本,一个普通版本,一个改写ES6写法,其大致写法如下:
<h2>一:普通版本</h2>
<b>结构部分</b>
<div id="box"></div>
注:先设置一个包围小球的盒子,当然不设置可以,那以浏览器可视窗口为基准。
<b>样式部分</b>

*{
            margin:0;
            padding:0;
        }
        #box{
            height:500px;
            width:600px;
            margin:20px auto;
            box-shadow: 0 0 3px #000;
            position: relative;
        }
        .ball{
            position: absolute;
            border-radius:50%;

        }

注:简单设置一下样式,盒子设置相对定位,小球相对于其设置绝对定位就可以了,小球不需要设置宽高,用JS控制随机大小和小球的颜色。下面是JS代码。

function Ball(){
            //小球的宽高
            this.wh = random(10,50);
            //小球的横向速度
            this.sx = random(-10,10,0);
            //小球的纵向速度
            this.sy = random(-10,10,0);
            //小球的颜色
            this.bg = 'rgb('+random(0,255)+','+random(0,255)+','+random(0,255)+')';
            //小球的位置 x轴
            this.left = random(10,600-50);
            //小球的位置 y轴
            this.top = random(10,500-50);
            this.box = null;
        }
        //小球出现的位置
        Ball.prototype.create = function(){
            //创建一个小球
            this.box = document.createElement('div');
            //获取创建的小球
            var box = document.getElementById('box');
            //小球距离和盒子左边的距离
            this.box.style.left = this.left+'px';
            //小球距离和盒子上边的距离
            this.box.style.top = this.top+'px';
            //小球的宽度
            this.box.style.width = this.wh+'px';
            //小球的高度
            this.box.style.height = this.wh+'px';
            //小球的背景颜色
            this.box.style.background = this.bg;
            //小球的样式
            this.box.className = 'ball';
            //把小球添加到div盒子上
            box.appendChild(this.box);
        }

        //小球移动
        Ball.prototype.move = function(){
            //小球撞到x轴左右两边设置反向移动,防止溢出
            if(this.left < 0 || this.left > 600 - this.wh){
                this.sx *= -1;
            }
            //小球撞到x轴上下两边设置反向移动,防止溢出
            if(this.top < 0 || this.top > 500 -this.wh){
                this.sy *= -1;
            }
            //左右移动
            this.left += this.sx;
            //上下移动
            this.top += this.sy;
            //设置盒子左边的距离
            this.box.style.left = this.left+'px';
            //设置盒子上边的距离
            this.box.style.top = this.top+'px';
        }

        // 随机函数,传入最大值,最小值和不想出现的值
        function random(min,max,not){
            //设置随机方法
            var result = Math.ceil(Math.random()*(max-min)+min);
            //跳过不想粗现的值
            if(result == not){
                result++;
            }
            //返回随机值
            return result;
        }

        //多个球
        var balls = [];
        //这里是设置20个球,想出现几个写几个
        for(var i = 0; i < 20;i++){
            //实例化一个要出现的小球对象
            var ball = new Ball();
            //调创建小球方法
            ball.create();
            balls[i] = ball;
        }
        // console.log(balls);
        //设置定时器,这里给了10毫秒
        var timer = setInterval(function(){
            for(var j = 0; j < balls.length; j++){
                balls[j].move();
            }
        },10)

注:在设置多个小球的时候不要给太多,否则很可能会卡的,当然你觉得你GPU足够强大可以试试,当然你如果非要给很多小球的话,四五千上万个话,建议用canvas做吧。强大的canvas哈哈。话入正题!上面时普通写法,基本没什么难度,写几个方法,控制边缘,调用方法就可以了。下面是改写的ES6新属性写法。
<h2>二:ES6版本</h2>
<h5>样式和结构不变,使用上面同一个</h5>

class Ball{
            constructor(){
                //球的宽高
                this.wh = random(10,50);
                //球的横向速度
                this.sx = random(-10,10,0);
                //球的纵向速度
                this.sy = random(-10,10,0);
                //球的颜色
                this.bg = `rgb(${random(0,255)},${random(0,255)},${random(0,255)})`;
                //球的位置 x轴
                this.left = random(10,600-50);
                //球的位置 y轴
                this.top = random(10,500-50);
                this.box = null;
                }
        

            create(){
                this.box = document.createElement('div');
                let box = document.querySelector('#box');
                this.box.style.cssText = `
                left:${this.left}px;
                top:${this.top}px;
                width:${this.wh}px;
                height:${this.wh}px;
                background:${this.bg};`;

                this.box.className = 'ball';
                box.appendChild(this.box);
            }

        //小球移动
        move(){
            if(this.left < 0 || this.left > 600 - this.wh){
                this.sx *= -1;
            }
            if(this.top < 0 || this.top > 500 -this.wh){
                this.sy *= -1;
            }
            this.left += this.sx;
            this.top += this.sy;
            this.box.style.left = this.left+'px';
            this.box.style.top = this.top+'px';
        }
    }
        // 随机函数,传入最大值,最小值和不想出现的值
        function random(min,max,not){
            let result = Math.ceil(Math.random()*(max-min)+min);
            if(result == not){
                result++;
            }
            return result;
        }

        //多个球
        let balls = [];
        for(let i = 0; i < 10;i++){
            let ball = new Ball();
            ball.create();
            balls[i] = ball;
        }
        // console.log(balls);

        const timer = setInterval(function(){
            for(let j = 0; j < balls.length; j++){
                balls[j].move();
            }
        },10)

附:注释和上面普通写法一样,这里不多写了,喜欢的朋友留个赞吧,感谢支持!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容

  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    呼呼哥阅读 3,269评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • 一、ES6简介 ​ 历时将近6年的时间来制定的新 ECMAScript 标准 ECMAScript 6(亦称 ...
    一岁一枯荣_阅读 5,961评论 8 25
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 11,618评论 4 59
  • 当未来还未来 你永远不知道,期待未来的喜悦和困守于现实的痛苦哪个会先到来!所以当未来还没来,当现实还无法逃开,那就...
    santanolife阅读 310评论 0 1