原生js實(shí)現(xiàn)彈跳小球
突發(fā)奇想,寫了個(gè)小球來(lái)回彈跳的案例,供大家參考,具體內(nèi)容如下
主要就是利用了margin-left / top 值進(jìn)行位移,當(dāng)然,也可以使用定位去做。
本案例所用到的有:
- DOM元素獲取
- DOM樣式操作
- .offsetWidth 獲取元素寬度
- .offsetHeight 獲取元素高度
- setInterval() 定時(shí)器
上代碼
整體使用原生js
<style> //style樣式 * { margin: 0; padding: 0; } #box { width: 500px; height: 600px; background-color: #eee; box-shadow: 0 0 10px 0 #000; margin: auto; overflow: hidden; position: relative; margin-top: 50px; } #box div { width: 50px; height: 50px; border-radius: 50%; background-color: #fff; position: absolute; } </style> <body> <div id="box"> <div id="cir"></div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> </div> </body> <script> var box = document.getElementById("box"); var cir = document.getElementById("cir") var cirs = box.querySelectorAll("div"); collMove(box, cir, 6); collMove(box, cirs[1], 7); collMove(box, cirs[2], 8); collMove(box, cirs[3], 9); collMove(box, cirs[4], 10); collMove(box, cirs[5], 10); collMove(box, cirs[6], 11); /** * 元素遇邊界彈開 * 彈開的同時(shí)改變?cè)仡伾? * @param {容器獲取} box * @param {容器內(nèi)彈跳元素獲取} cir * @param {彈跳速度} speed */ function collMove(box, cir, speed) {//方法封裝 var oDiv = box; //獲取容器 var oCir = cir; //獲取容器內(nèi)元素 var xMax = oDiv.offsetWidth - oCir.offsetWidth; //容器最大X軸邊界 var yMax = oDiv.offsetHeight - oCir.offsetHeight; //容器最大Y軸邊界 var motionX = 0; //元素X軸坐標(biāo)初始化 var motionY = 0; //元素y軸坐標(biāo)初始化 (() => { var speedX = speed; //x軸偏移量 var speedY = speed; //y軸偏移量 setInterval(() => { motionX += speedX; //進(jìn)行X軸偏移 motionY += speedY; //進(jìn)行y軸偏移 if (motionX >= xMax) { //檢測(cè)是否碰到X軸右邊界 motionX = xMax; //碰到邊界將X軸坐標(biāo)設(shè)為x軸最大右邊界 speedX = -speedX; //x軸偏移量反轉(zhuǎn) randColor(oCir); //改變顏色 } else if (motionX <= 0) { //檢測(cè)是否碰到X左邊界 motionX = 0; //碰到邊界將X軸坐標(biāo)設(shè)為 0 即左邊界初始位置 speedX = -speedX; //再次反轉(zhuǎn)X軸偏移量 randColor(oCir); //下方上下邊界檢測(cè)同理 } if (motionY >= yMax) { motionY = yMax; speedY = -speedY randColor(oCir); } else if (motionY <= 0) { motionY = 0; speedY = -speedY; randColor(oCir); } oCir.style.marginLeft = motionX + "px"; //設(shè)置元素X軸坐標(biāo) oCir.style.marginTop = motionY + "px"; //設(shè)置元素Y軸坐標(biāo) }, 10); })(); function randColor(obj) { //封裝一個(gè)隨機(jī)色彩,改變顏色直接調(diào)用 var op = Math.random() * 7 + 3; function color() { return Math.floor(Math.random() * 256); } return obj.style.backgroundColor = `rgba(${color()},${color()},${color()},${op})`; } } </script>
整個(gè)方法中,最主要的就是理解元素位置與容器邊界的檢測(cè)與判斷,這一部分搞懂,剩下的就很簡(jiǎn)單了。
有個(gè)小提示:容器不要設(shè)置成標(biāo)準(zhǔn)的正方形,不然會(huì)因?yàn)榻嵌鹊脑?,小球只能從左上角到右下角?lái)回彈動(dòng)。
整個(gè)方法都已封裝,需要用時(shí),只需要復(fù)制整個(gè)方法或者外鏈進(jìn)去 然后直接使用方法名依照對(duì)應(yīng)參數(shù)調(diào)用即可。一個(gè)元素一次調(diào)用. 閑麻煩可直接寫一個(gè)for循環(huán)去循環(huán)調(diào)用。
拋個(gè)磚:
for(var i = 1 ; i<=10;i++){ collMove(box,cirs[i],i); }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript+canvas實(shí)現(xiàn)框內(nèi)跳動(dòng)小球
- JavaScript結(jié)合Canvas繪畫畫運(yùn)動(dòng)小球
- JavaScript canvas實(shí)現(xiàn)跟隨鼠標(biāo)移動(dòng)小球
- 原生js實(shí)現(xiàn)移動(dòng)小球(碰撞檢測(cè))
- js實(shí)現(xiàn)小球在頁(yè)面規(guī)定的區(qū)域運(yùn)動(dòng)
- 用js實(shí)現(xiàn)小球的自由移動(dòng)代碼
- js實(shí)現(xiàn)跟隨鼠標(biāo)移動(dòng)的小球
- JavaScript實(shí)現(xiàn)小球沿正弦曲線運(yùn)動(dòng)
- p5.js入門教程之小球動(dòng)畫示例代碼
- 原生js實(shí)現(xiàn)彈動(dòng)小球效果
相關(guān)文章
聊聊JS動(dòng)畫庫(kù) Velocity.js的使用
本篇文章主要介紹了聊聊JS動(dòng)畫庫(kù) Velocity.js的使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03chrome瀏覽器當(dāng)表單自動(dòng)填充時(shí)如何去除瀏覽器自動(dòng)添加的默認(rèn)樣式
很多朋友都遇到這個(gè)問(wèn)題:當(dāng)使用chrome瀏覽器表單自動(dòng)填充時(shí)都會(huì)自動(dòng)添加默認(rèn)的樣式,該如何去除默認(rèn)樣式呢?看看小編是怎么去除的,需要的朋友一起學(xué)習(xí)吧2015-10-10layui 彈出層回調(diào)獲取彈出層數(shù)據(jù)的例子
今天小編就為大家分享一篇layui 彈出層回調(diào)獲取彈出層數(shù)據(jù)的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09javascript中使用正則計(jì)算中文長(zhǎng)度的例子
這篇文章主要介紹了javascript中使用正則計(jì)算中文長(zhǎng)度的例子,需要的朋友可以參考下2014-04-04javascript數(shù)組對(duì)象常用api函數(shù)小結(jié)(連接,插入,刪除,反轉(zhuǎn),排序等)
這篇文章主要介紹了javascript數(shù)組對(duì)象常用api函數(shù),結(jié)合實(shí)例形式總結(jié)分析了javascript針對(duì)數(shù)組的連接、刪除、反轉(zhuǎn)、排序、插入等操作相關(guān)函數(shù)用法,需要的朋友可以參考下2016-09-09javascript實(shí)現(xiàn)小型區(qū)塊鏈功能
這篇文章主要介紹了javascript實(shí)現(xiàn)小型區(qū)塊鏈功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Javascript學(xué)習(xí)之談?wù)凧S的全局變量跟局部變量(推薦)
這篇文章主要介紹了Javascript學(xué)習(xí)之談?wù)凧S的全局變量跟局部變量雖然腳本之家小編以前發(fā)過(guò),但還是這篇文章整理的比較好,需要的朋友可以參考一下2016-08-08JavaScript實(shí)現(xiàn)標(biāo)題欄文字輪播效果代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)標(biāo)題欄文字輪播效果代碼,涉及JavaScript基于時(shí)間函數(shù)及流程控制操作標(biāo)題欄文字的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10轉(zhuǎn)換json格式的日期為Javascript對(duì)象的函數(shù)
項(xiàng)目中碰到了用jQuery從后臺(tái)獲取的json格式的日期的字符串,需要將此字符串轉(zhuǎn)換成JavaScript的日期對(duì)象,記在此處,以備后用。2010-07-07