原生js實現(xiàn)彈跳小球
突發(fā)奇想,寫了個小球來回彈跳的案例,供大家參考,具體內(nèi)容如下
主要就是利用了margin-left / top 值進行位移,當(dāng)然,也可以使用定位去做。
本案例所用到的有:
- DOM元素獲取
- DOM樣式操作
- .offsetWidth 獲取元素寬度
- .offsetHeight 獲取元素高度
- setInterval() 定時器
上代碼
整體使用原生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);
/**
* 元素遇邊界彈開
* 彈開的同時改變元素顏色
* @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; //進行X軸偏移
motionY += speedY; //進行y軸偏移
if (motionX >= xMax) { //檢測是否碰到X軸右邊界
motionX = xMax; //碰到邊界將X軸坐標(biāo)設(shè)為x軸最大右邊界
speedX = -speedX; //x軸偏移量反轉(zhuǎn)
randColor(oCir); //改變顏色
} else if (motionX <= 0) { //檢測是否碰到X左邊界
motionX = 0; //碰到邊界將X軸坐標(biāo)設(shè)為 0 即左邊界初始位置
speedX = -speedX; //再次反轉(zhuǎn)X軸偏移量
randColor(oCir); //下方上下邊界檢測同理
}
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) { //封裝一個隨機色彩,改變顏色直接調(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>
整個方法中,最主要的就是理解元素位置與容器邊界的檢測與判斷,這一部分搞懂,剩下的就很簡單了。
有個小提示:容器不要設(shè)置成標(biāo)準(zhǔn)的正方形,不然會因為角度的原因,小球只能從左上角到右下角來回彈動。
整個方法都已封裝,需要用時,只需要復(fù)制整個方法或者外鏈進去 然后直接使用方法名依照對應(yīng)參數(shù)調(diào)用即可。一個元素一次調(diào)用. 閑麻煩可直接寫一個for循環(huán)去循環(huán)調(diào)用。
拋個磚:
for(var i = 1 ; i<=10;i++){
collMove(box,cirs[i],i);
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
chrome瀏覽器當(dāng)表單自動填充時如何去除瀏覽器自動添加的默認(rèn)樣式
很多朋友都遇到這個問題:當(dāng)使用chrome瀏覽器表單自動填充時都會自動添加默認(rèn)的樣式,該如何去除默認(rèn)樣式呢?看看小編是怎么去除的,需要的朋友一起學(xué)習(xí)吧2015-10-10
layui 彈出層回調(diào)獲取彈出層數(shù)據(jù)的例子
今天小編就為大家分享一篇layui 彈出層回調(diào)獲取彈出層數(shù)據(jù)的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
javascript數(shù)組對象常用api函數(shù)小結(jié)(連接,插入,刪除,反轉(zhuǎn),排序等)
這篇文章主要介紹了javascript數(shù)組對象常用api函數(shù),結(jié)合實例形式總結(jié)分析了javascript針對數(shù)組的連接、刪除、反轉(zhuǎn)、排序、插入等操作相關(guān)函數(shù)用法,需要的朋友可以參考下2016-09-09
Javascript學(xué)習(xí)之談?wù)凧S的全局變量跟局部變量(推薦)
這篇文章主要介紹了Javascript學(xué)習(xí)之談?wù)凧S的全局變量跟局部變量雖然腳本之家小編以前發(fā)過,但還是這篇文章整理的比較好,需要的朋友可以參考一下2016-08-08
JavaScript實現(xiàn)標(biāo)題欄文字輪播效果代碼
這篇文章主要介紹了JavaScript實現(xiàn)標(biāo)題欄文字輪播效果代碼,涉及JavaScript基于時間函數(shù)及流程控制操作標(biāo)題欄文字的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10
轉(zhuǎn)換json格式的日期為Javascript對象的函數(shù)
項目中碰到了用jQuery從后臺獲取的json格式的日期的字符串,需要將此字符串轉(zhuǎn)換成JavaScript的日期對象,記在此處,以備后用。2010-07-07

