jQuery實現(xiàn)碰到邊緣反彈的動畫效果
先上效果圖:

錄出來有點卡頓的趕腳,實際上還是挺順暢的。
1.HTML:
<div class="box"></div>
2.CSS:
body{
background:skyblue
}
.box{
position: absolute;
top: 10px;
left: 10px;
width: 100px;
height: 100px;
background: white;
}
3.JS:
$(function(){
var obj=$(".box");
var x=obj.offset().left;//盒子距離左部的位置
var y=obj.offset().top;//盒子距離頂部的位置
var objwid=obj.width();//盒子的寬
var objhei=obj.height();
var winwid=$(window).width();//頁面的寬
var winhei=$(window).height();
var max=10;//設(shè)置最大視覺差,就是感覺這個距離剛好碰到
var winx=winwid-objwid-max;//盒子x軸最遠達到的距離
var winy=winhei-objhei-max;//盒子y軸最遠達到的距離
var sx=0;//x軸是否返回的狀態(tài),0是值++即正向移動,1是值--即返回
var sy=0;
time1=setInterval(function(){
if(sx==0){
obj.css("left",x++);
}else if(sx==1){
obj.css("left",x--);
}
if(x<=0){
sx=0;
}else if(x>=winx){
sx=1;
}
if(sy==0){
obj.css("top",y++);
}else if(sy==1){
obj.css("top",y--);
}
if(y<=0){
sy=0;
}else if(y>=winy){
sy=1;
}
},1)
})
這里只是簡單的效果,由此可引發(fā)多個問題:
1)如果多個方塊出現(xiàn),頁面會不會卡頓呢?
2)如果要實現(xiàn)多個方塊碰撞之后改變運動的位置,這個怎么做呢?
3)方塊的初始位置能不能隨機呢?
4)多個方塊的速度怎樣設(shè)置不一樣呢
5)能不能做一個彈方塊的小游戲?
總結(jié)
以上所述是小編給大家介紹的jQuery實現(xiàn)碰到邊緣反彈的動畫效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
使用jQuery向asp.net Mvc傳遞復雜json數(shù)據(jù)-ModelBinder篇
jQuery提供的ajax方法能很方便的實現(xiàn)客戶端與服務器的異步交互,在asp.net mvc 框架使用jQuery能很方便地異步獲取提交數(shù)據(jù),給用戶提供更好的體驗!2010-05-05
清空元素html("") innerHTML="" 與 empty()的區(qū)別和應用(推薦)
這篇文章主要介紹了清空元素html("")、innerHTML="" 與 empty()的區(qū)別和應用,詳細介紹了三者之間的原理及應用,需要的朋友可以參考下2017-08-08
jQuery替換節(jié)點用法示例(使用replaceWith方法)
這篇文章主要介紹了jQuery替換節(jié)點的方法,結(jié)合簡單實例形式分析了jQuery使用replaceWith方法替換P標簽顯示內(nèi)容的相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-09-09

