Maison > Article > interface Web > JS implémente un effet de défilement basé sur l'écran avec de bonnes compétences en compatibilité_javascript
L'exemple de cet article décrit l'implémentation JS d'un effet de défilement basé sur un écran avec une bonne compatibilité. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Les paramètres dans le code sont expliqués comme suit :
id L'identifiant du contenu que vous souhaitez faire défiler
l La position de l'abscisse ne s'écrit pas aussi près de la droite
t La position que vous souhaitez placer sur la page est par défaut le bord inférieur 0 signifie le bord supérieur
.
f 1 signifie fixe, non écrit ou 0 signifie roulant.
Ce code ne tremblera pas lors du défilement et change avec la taille de l'écran
La capture d'écran de l'effet en cours d'exécution est la suivante :
L'adresse de la démo en ligne est la suivante :
http://demo.jb51.net/js/2015/js-scroll-follow-src-style-codes/
Le code spécifique est le suivant :
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gbk" /> <title>随屏滚动</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;" >我静止不动</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)//控制滚动的频率越大频率越慢 } }() } } } } scroll({ id:'aa' }) scroll({ id:'bb', l:0, t:200, f:1 }) </script>
J'espère que cet article sera utile à tout le monde dans la programmation JavaScript.