JavaScript實(shí)現(xiàn)跟隨滾動(dòng)緩沖運(yùn)動(dòng)廣告框
當(dāng)我們?yōu)g覽一些網(wǎng)頁(yè)時(shí)我們會(huì)發(fā)現(xiàn)頁(yè)面的的邊上會(huì)有廣告圖片,當(dāng)滾動(dòng)滾動(dòng)條的時(shí)候這些廣告圖片會(huì)跟隨性的隨頁(yè)面一起運(yùn)動(dòng)(這里我叫它為廣告框)。一些網(wǎng)頁(yè)的廣告框是固定在瀏覽器上的用background:fixed;便可實(shí)現(xiàn)。這里我用JavaScript簡(jiǎn)單的制作了一個(gè)隨滾動(dòng)緩沖運(yùn)動(dòng)的廣告框。

制作的原理比較簡(jiǎn)單,大家都有一個(gè)完美的js運(yùn)動(dòng)框架,這里的緩沖運(yùn)動(dòng)需要用到。這里的廣告框設(shè)定的是跟隨滾動(dòng)條緩沖運(yùn)動(dòng)并運(yùn)動(dòng)到瀏覽器的中間位置。需要理解的是運(yùn)動(dòng)距離的計(jì)算和一些細(xì)節(jié)上的處理(一些BUG的預(yù)防)
這是我在這里使用的一個(gè)js運(yùn)動(dòng)框架,傳遞的參數(shù)只有一個(gè)并不是完美運(yùn)動(dòng)框架。傳遞的參數(shù)是廣告框的運(yùn)動(dòng)距離,因此我在運(yùn)動(dòng)框架內(nèi)又獲取了一次對(duì)象。
var timer=null;
function startMover(iTarget){
var oDiv=document.getElementById('div1');
clearInterval(timer);
timer=setInterval(function(){
var ispeed=(iTarget-oDiv.offsetTop)/8;
//速度設(shè)置為逐漸減小
ispeed=ispeed>0?Math.ceil(ispeed):Math.floor(ispeed);
//避免速度產(chǎn)生小數(shù)點(diǎn)
if(oDiv.offsetTop==iTarget){
clearInterval(timer);
}
else{
oDiv.style.top=oDiv.offsetTop+ispeed+"px";
}
},30);
};
樣式和布局代碼
<style>
#div1{
width: 100px;
height: 100px;
background: #ccc;
position: absolute;
//使用絕對(duì)定位讓其處于右上方
right: 0;
top: 0;
</style>
<body style="height: 2000px;">
<div id="div1"></div>
</body>
js代碼
這里增加了.onscroll屬性目的是當(dāng)滾動(dòng)滾動(dòng)條的時(shí)候也加載頁(yè)面,廣告框就能隨著滾動(dòng)條一起運(yùn)動(dòng)了。還增加了.onresize屬性,由于我要實(shí)現(xiàn)廣告框一直是運(yùn)動(dòng)到瀏覽器的中間位置,然而當(dāng)我改變?yōu)g覽器高度的時(shí)候也要實(shí)現(xiàn)廣告框的運(yùn)動(dòng),所以增加該屬性,當(dāng)瀏覽器大小改變時(shí)加載。
<script>
window.onload=window.onscroll=window.onresize=function(){
var oDiv=document.getElementById('div1');
var scrolltop=document.documentElement.scrollTop||document.body.scrollTop;
"scrolltop"是滾動(dòng)條滾動(dòng)的距離,這里有一個(gè)兼容chrome不支持document.documentElement.scrollTop獲取語(yǔ)句,其他瀏覽器支持。
var t=(document.documentElement.clientHeight-oDiv.offsetHeight)/2;
"t"為讓廣告框處于中間位置的高度距離,(獲取瀏覽器的總高度-廣告框自身高度)/2
startMover(parseInt(t+scrolltop));
"parseIn"返回一個(gè)整數(shù),避免小數(shù)生成。這里廣告框的總移動(dòng)距離為(t+scrolltop)
};
var timer=null;
function startMover(iTarget){
var oDiv=document.getElementById('div1');
clearInterval(timer);
timer=setInterval(function(){
var ispeed=(iTarget-oDiv.offsetTop)/8;
ispeed=ispeed>0?Math.ceil(ispeed):Math.floor(ispeed);
if(oDiv.offsetTop==iTarget){
clearInterval(timer);
}
else{
oDiv.style.top=oDiv.offsetTop+ispeed+"px";
}
},30);
};
</script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js綜合應(yīng)用實(shí)例簡(jiǎn)單的表格統(tǒng)計(jì)
在做調(diào)查問(wèn)卷的過(guò)程中,遇到一個(gè)表格的統(tǒng)計(jì)問(wèn)題,一個(gè)需要用到j(luò)s方面的綜合知識(shí),感覺(jué)還不錯(cuò)所以記錄下來(lái)與大家分享,感興趣的朋友可以了解下2013-09-09
JavaScript鍵盤(pán)事件超詳細(xì)總結(jié)
這篇文章主要給大家介紹了關(guān)于JavaScript鍵盤(pán)事件的相關(guān)資料,鍵盤(pán)事件是指在網(wǎng)頁(yè)中當(dāng)用戶(hù)按下鍵盤(pán)上的按鍵時(shí)所觸發(fā)的事件,在JavaScript中可以通過(guò)監(jiān)聽(tīng)鍵盤(pán)事件來(lái)實(shí)現(xiàn)一些交互效果,需要的朋友可以參考下2023-10-10
JavaScript中valueOf函數(shù)與toString方法深入理解
基本上,所有JS數(shù)據(jù)類(lèi)型都擁有valueOf和toString這兩個(gè)方法,null除外。它們倆解決javascript值運(yùn)算與顯示的問(wèn)題,本文將詳細(xì)介紹,有需要的朋友可以參考下2012-12-12
深入理解在JS中通過(guò)四種設(shè)置事件處理程序的方法
所有的JavaScript事件處理程序的作用域是在其定義時(shí)的作用域而非調(diào)用時(shí)的作用域中執(zhí)行,并且它們能存取那個(gè)作用域中的任何一個(gè)本地變量。但是HTML標(biāo)簽屬性注冊(cè)處理程序就是一個(gè)例外。看下面四種方式2017-03-03
ichart.js繪制虛線(xiàn)、平均分虛線(xiàn)效果的實(shí)現(xiàn)代碼
下面小編就為大家?guī)?lái)一篇ichart.js繪制虛線(xiàn)、平均分虛線(xiàn)效果的實(shí)現(xiàn)代碼。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-05-05
JavaScript實(shí)現(xiàn)模態(tài)框拖拽效果
這篇文章主要介紹了通過(guò)JavaScript實(shí)現(xiàn)模態(tài)框拖拽的效果,以及鼠標(biāo)松開(kāi),可以停止拖動(dòng)模態(tài)框移動(dòng)等功能,感興趣的小伙伴可以了解一下2021-12-12
微信小程序?qū)崿F(xiàn)頂部選項(xiàng)卡(swiper)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)頂部選項(xiàng)卡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08

