JS實(shí)現(xiàn)兼容性較好的隨屏滾動(dòng)效果
本文實(shí)例講述了JS實(shí)現(xiàn)兼容性較好的隨屏滾動(dòng)效果。分享給大家供大家參考,具體如下:
代碼中的參數(shù)解釋如下:
id 你要滾動(dòng)的內(nèi)容的id
l 橫坐標(biāo)的位置 不寫為緊貼右邊
t 你要放在頁(yè)面的那個(gè)位置默認(rèn)是貼著底邊 0是貼著頂邊
f 1表示固定 不寫或者0表示滾動(dòng)。
本代碼滾動(dòng)時(shí)不會(huì)出現(xiàn)抖動(dòng),隨著屏幕大小而變動(dòng)
運(yùn)行效果截圖如下:
在線演示地址如下:
http://demo.jb51.net/js/2015/js-scroll-follow-src-style-codes/
具體代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gbk" /> <title>隨屏滾動(dòng)</title> <style> html,body{ padding:0; margin:0; } </style> </head> <body> <div id="aa" style="width:200px;height:200px;background:#c0c0c0;" >我在隨屏滾</div> <div id="bb" style="width:200px;height:200px;background:#c0c0c0;" >我靜止不動(dòng)</div> <div style="width:100%;height:500px;background:#000"></div> <div style="width:100%;height:500px;background:green"></div> <div style="width:100%;height:500px;background:red"></div> </body> </html> <script> function scroll(p){ var d = document,dd = d.documentElement,db = d.body,w = window,o = d.getElementById(p.id),ie = /msie/i.test(navigator.userAgent),style; if(o){ o.style.cssText +=";position:"+(p.f&&!ie?'fixed':'absolute')+";"+(p.l==undefined?'right:0;':'left:'+p.l+'px;')+(p.t!=undefined?'top:'+p.t+'px':'bottom:0'); if(p.f&&ie){ o.style.cssText +=';left:expression(body.scrollLeft + '+(p.l==undefined?db.clientWidth-o.offsetWidth:p.l)+' + "px");top:expression(body.scrollTop +'+(p.t==undefined?db.clientHeight-o.offsetHeight:p.t)+'+ "px" );' db.style.cssText +=";background-image:url(about:blank);background-attachment:fixed;" }else{ if(!p.f){ w.onresize = w.onscroll = function(){ var timer,timer1; return function(){ if(timer) clearTimeout(timer); timer = setTimeout(function(){ timer1 = setInterval(function(){ var st = db.scrollTop,c; c = st - o.offsetTop + (p.t!=undefined?p.t:(w.innerHeight||db.clientHeight)-o.offsetHeight); if(c!=0){ o.style.top = o.offsetTop + Math.ceil(Math.abs(c)/10)*(c<0?-1:1) + 'px'; }else{ clearInterval(timer1); } },10) },100)//控制滾動(dòng)的頻率越大頻率越慢 } }() } } } } scroll({ id:'aa' }) scroll({ id:'bb', l:0, t:200, f:1 }) </script>
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JavaScript中解決多瀏覽器兼容性23個(gè)問題的快速解決方法
- 常用原生JS兼容性寫法匯總
- JavaScript 瀏覽器兼容性總結(jié)及常用瀏覽器兼容性分析
- 深入淺析JavaScript字符串操作方法 slice、substr、substring及其IE兼容性
- JS實(shí)現(xiàn)兼容性好,自動(dòng)置頂?shù)奶詫殤腋」ぞ邫谛Ч?/a>
- javascript中setAttribute()函數(shù)使用方法及兼容性
- css與javascript跨瀏覽器兼容性總結(jié)
- js日期對(duì)象兼容性的處理方法
- Javascript 多瀏覽器兼容性問題及解決方案
- JavaScript的兼容性與調(diào)試技巧
相關(guān)文章
Google的跟蹤代碼 動(dòng)態(tài)加載js代碼方法應(yīng)用
Google的跟蹤代碼 動(dòng)態(tài)加載js代碼,需要的朋友可以參考下2012-11-11uniapp組件傳值的方法(父?jìng)髯?子傳父,對(duì)象傳值)實(shí)戰(zhàn)案例
現(xiàn)在的前端開發(fā)中基本上都是組件化開發(fā)的,下面這篇文章主要給大家介紹了關(guān)于uniapp組件傳值(父?jìng)髯?子傳父,對(duì)象傳值)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03學(xué)習(xí)JavaScript設(shè)計(jì)模式之單例模式
這篇文章主要為大家介紹了JavaScript設(shè)計(jì)模式中的單例模式,對(duì)JavaScript設(shè)計(jì)模式感興趣的小伙伴們可以參考一下2016-01-01原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果
本文主要分享了原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果的示例代碼,并解析了實(shí)例中的注意點(diǎn)。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-01-01基于Bootstrap的網(wǎng)頁(yè)設(shè)計(jì)實(shí)例
這篇文章主要介紹了基于Bootstrap的網(wǎng)頁(yè)設(shè)計(jì)實(shí)例,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03