Accueil > > > SCROLLBAR PERSONNALISABLE
SCROLLBAR PERSONNALISABLE
Information sur la source
Description
il s'agit de barre de scroll en javascript personnalisable avec le css j'avait fait une source dans ce genre mais elle n'etait pas parfaite j'ai donc refait une source completement differente et fonctionnant nettement mieux seul le principe d'utiliser les marges a ete conservé tout est automatisé il suffit de créer sa barre de scroll avec le css d'ajouter un onmousedown au curseur de scroll pour appeler la fonction en lui precisant l'element qui doit etre scrollé le reste se fera automatiquement. ++
Source
- var kscroll={
-
- vascro:0,
- setX:0,
- setY:0,
- px:0,
- py:0,
- elem:null,
- elem2:null,
- direction:null,
- dde:document.documentElement,
-
- selecte:function(ev){
- ev.preventDefault();
- },
-
- sp:function(evt,trez){
-
- evt =(!evt) ? window.event : evt;
- kscroll.elem=((navigator.userAgent.substring(30,31))<=8) ? evt.srcElement : evt.currentTarget;
-
- if(arguments.length<=1){
- if((navigator.userAgent.substring(30,31))<=8){
- kscroll.dde.detachEvent("onmouseup",kscroll.sp);
- kscroll.dde.detachEvent("onmousemove",kscroll.f_scroll);
- }
- else{
- kscroll.dde.removeEventListener("mousedown", kscroll.selecte, false);
- kscroll.dde.removeEventListener("mousemove", kscroll.f_scroll, false);
- kscroll.dde.removeEventListener("mouseup", kscroll.sp, false);
- }
- }
-
- if(arguments.length>=2){
- kscroll.elem2=document.getElementById(trez);
- var rcsb =kscroll.elem;
-
- if(kscroll.elem.parentNode.offsetWidth > kscroll.elem.parentNode.offsetHeight){
- kscroll.direction="horizon";
-
- kscroll.vascro=((navigator.userAgent.substring(30,31))<=8) ? parseInt(rcsb.currentStyle.marginLeft) : parseInt(getComputedStyle(rcsb, null).getPropertyValue('margin-left'));
- }
- else{
- kscroll.direction="vertical";
- kscroll.vascro=((navigator.userAgent.substring(30,31))<=8) ? parseInt(rcsb.currentStyle.marginTop) : kscroll.vascro=parseInt(getComputedStyle(rcsb, null).getPropertyValue('margin-top'));
- }
-
- if((navigator.userAgent.substring(30,31))<=8){
- kscroll.dde.attachEvent("onmousemove",kscroll.f_scroll);
- kscroll.dde.attachEvent ("onmouseup",kscroll.sp);
- }
- else{
- kscroll.dde.addEventListener("mousemove", kscroll.f_scroll, false);
- kscroll.dde.addEventListener("mousedown", kscroll.selecte, false);
- kscroll.dde.addEventListener("mouseup", kscroll.sp, false);
- }
-
- kscroll.setX=evt.clientX;
- kscroll.setY=evt.clientY;
- kscroll.px=kscroll.setX;
- kscroll.py=kscroll.setY;
- }
- },
-
-
- f_scroll:function(s){
-
- s =(!s) ? window.event : s;
- s.returnValue = false;
- kscroll.setX =s.clientX;
- kscroll.setY =s.clientY;
-
- var tbm=kscroll.elem2;
- var ds2=tbm.getElementsByTagName('*')[0];
- var ds1 =kscroll.elem.parentNode;
- var rcsb =kscroll.elem;
-
- if(kscroll.direction=="horizon"){
- kscroll.vascro+=(kscroll.setX-kscroll.px);
- if(kscroll.vascro<=0){
- rcsb.style.marginLeft=0+'px';
- }
- else if(kscroll.vascro>=ds1.offsetWidth-rcsb.offsetWidth){
- rcsb.style.marginLeft=(ds1.offsetWidth-rcsb.offsetWidth)+'px';
- }
- else{
- rcsb.style.marginLeft=kscroll.vascro+'px';
- }
- kscroll.px=kscroll.setX;
- kscroll.py=kscroll.setY;
- var valeur=(parseInt(rcsb.style.marginLeft)/(ds1.offsetWidth-rcsb.offsetWidth)).toFixed(2);
- document.getElementById('nbfic').value=valeur;
- ds2.style.marginLeft=-(valeur*(ds2.offsetWidth-tbm.offsetWidth))+'px';
- }
-
- else{
- kscroll.vascro+=(kscroll.setY-kscroll.py)
- if(kscroll.vascro<=0){
- rcsb.style.marginTop=0+'px';
- }
- else if(kscroll.vascro>=ds1.offsetHeight-rcsb.offsetHeight){
- rcsb.style.marginTop=(ds1.offsetHeight-rcsb.offsetHeight)+'px';
- }
- else{
- rcsb.style.marginTop=kscroll.vascro+'px';
- }
- kscroll.px=kscroll.setX;
- kscroll.py=kscroll.setY;
- var valeur=(parseInt(rcsb.style.marginTop)/(ds1.offsetHeight-rcsb.offsetHeight)).toFixed(2)
- document.getElementById('nbfic').value=valeur
- ds2.style.marginTop=-(valeur*(ds2.offsetHeight-tbm.offsetHeight))+'px';
- }
- }
-
- }
var kscroll={
vascro:0,
setX:0,
setY:0,
px:0,
py:0,
elem:null,
elem2:null,
direction:null,
dde:document.documentElement,
selecte:function(ev){
ev.preventDefault();
},
sp:function(evt,trez){
evt =(!evt) ? window.event : evt;
kscroll.elem=((navigator.userAgent.substring(30,31))<=8) ? evt.srcElement : evt.currentTarget;
if(arguments.length<=1){
if((navigator.userAgent.substring(30,31))<=8){
kscroll.dde.detachEvent("onmouseup",kscroll.sp);
kscroll.dde.detachEvent("onmousemove",kscroll.f_scroll);
}
else{
kscroll.dde.removeEventListener("mousedown", kscroll.selecte, false);
kscroll.dde.removeEventListener("mousemove", kscroll.f_scroll, false);
kscroll.dde.removeEventListener("mouseup", kscroll.sp, false);
}
}
if(arguments.length>=2){
kscroll.elem2=document.getElementById(trez);
var rcsb =kscroll.elem;
if(kscroll.elem.parentNode.offsetWidth > kscroll.elem.parentNode.offsetHeight){
kscroll.direction="horizon";
kscroll.vascro=((navigator.userAgent.substring(30,31))<=8) ? parseInt(rcsb.currentStyle.marginLeft) : parseInt(getComputedStyle(rcsb, null).getPropertyValue('margin-left'));
}
else{
kscroll.direction="vertical";
kscroll.vascro=((navigator.userAgent.substring(30,31))<=8) ? parseInt(rcsb.currentStyle.marginTop) : kscroll.vascro=parseInt(getComputedStyle(rcsb, null).getPropertyValue('margin-top'));
}
if((navigator.userAgent.substring(30,31))<=8){
kscroll.dde.attachEvent("onmousemove",kscroll.f_scroll);
kscroll.dde.attachEvent ("onmouseup",kscroll.sp);
}
else{
kscroll.dde.addEventListener("mousemove", kscroll.f_scroll, false);
kscroll.dde.addEventListener("mousedown", kscroll.selecte, false);
kscroll.dde.addEventListener("mouseup", kscroll.sp, false);
}
kscroll.setX=evt.clientX;
kscroll.setY=evt.clientY;
kscroll.px=kscroll.setX;
kscroll.py=kscroll.setY;
}
},
f_scroll:function(s){
s =(!s) ? window.event : s;
s.returnValue = false;
kscroll.setX =s.clientX;
kscroll.setY =s.clientY;
var tbm=kscroll.elem2;
var ds2=tbm.getElementsByTagName('*')[0];
var ds1 =kscroll.elem.parentNode;
var rcsb =kscroll.elem;
if(kscroll.direction=="horizon"){
kscroll.vascro+=(kscroll.setX-kscroll.px);
if(kscroll.vascro<=0){
rcsb.style.marginLeft=0+'px';
}
else if(kscroll.vascro>=ds1.offsetWidth-rcsb.offsetWidth){
rcsb.style.marginLeft=(ds1.offsetWidth-rcsb.offsetWidth)+'px';
}
else{
rcsb.style.marginLeft=kscroll.vascro+'px';
}
kscroll.px=kscroll.setX;
kscroll.py=kscroll.setY;
var valeur=(parseInt(rcsb.style.marginLeft)/(ds1.offsetWidth-rcsb.offsetWidth)).toFixed(2);
document.getElementById('nbfic').value=valeur;
ds2.style.marginLeft=-(valeur*(ds2.offsetWidth-tbm.offsetWidth))+'px';
}
else{
kscroll.vascro+=(kscroll.setY-kscroll.py)
if(kscroll.vascro<=0){
rcsb.style.marginTop=0+'px';
}
else if(kscroll.vascro>=ds1.offsetHeight-rcsb.offsetHeight){
rcsb.style.marginTop=(ds1.offsetHeight-rcsb.offsetHeight)+'px';
}
else{
rcsb.style.marginTop=kscroll.vascro+'px';
}
kscroll.px=kscroll.setX;
kscroll.py=kscroll.setY;
var valeur=(parseInt(rcsb.style.marginTop)/(ds1.offsetHeight-rcsb.offsetHeight)).toFixed(2)
document.getElementById('nbfic').value=valeur
ds2.style.marginTop=-(valeur*(ds2.offsetHeight-tbm.offsetHeight))+'px';
}
}
}
Conclusion
UN... DEUX... TROIS...
Historique
- 04 juillet 2011 00:46:44 :
- debogage
- 11 juillet 2011 13:08:28 :
- mise a jour html
Sources du même auteur
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
scrollbar dans popup [ par lili_jazzy ]
bonjour,j'ai une popup avec scrolbars=yesmais je ne voudrais avoir que la scrolbar verticale et non celle horizontale même en ayant une page
Defilement d'une scroll bar [ par zipzip ]
problème de couleur de scroll barre [ par fogof ]
J'ai paramétré la couleur de mes scroll barre en css dans le body { , mais ces paramètres ne sont pas prient en compte dans ma fra
Positionnement dans une Scrollbar [ par tets88 ]
Bonjour, J'ai un petit soucis avec un code que j'ai trouvé sur le site [url=http://www.dyn-web.com/code/scroll/]http://www.dyn-web.com/code/scroll/[/
bloquer un div en haut de page lors d'un scroll vertical [ par BBFUNK01 ]
Hello, je suis en train d'essayer de reproduire l'effet qu'on peut voir sur le site de Deezer : [url=http://www.deezer.com/fr/]Deezer[/url], à savoir
Intégrer un timer dans un slieshow [ par quinton75 ]
Bonjour [^^clinoeil1][^^clinoeil1] Je ne m'y connais pas du tout en js donc malgré divers tuto de slideshow je rame Je souhaite faire defiler mes ph
div qui suit le scrolling de la page => PETOLETEAM [ par torg33 ]
Bonjour tout le monde, je viens d'intégrer le script de PetoleTeam à mon portfolio et je tiens a dire que c'est tout à fait ce qu'il me faut. Mais (et
script de defilement d'image [ par sidomed ]
étant novice dans le javascript, je cherche à faire défiler des image qui sont stocké dans un dossier min et au méme temps dans une base de donnée l&#
Bouger deux ScrollBar en même temps [ par BeberEberlue ]
Bonjour Je cherche à faire en sorte que mes deux scrollbar horizontales bougent en même temps, c-a-d qui si l'utilisateur déplace la première scrollb
[Dreamweaver] Onglet avec scrollbar [ par grominnetto ]
Bonjour tout le monde, voici, je tente de créer un site pour une école de hockey et j'aimerais avoir une barre de défilement (ou scrollbar) avec quel
|
Derniers Blogs
IMAGINE CUP 2012, MAKE A SIGN EN FINALEIMAGINE CUP 2012, MAKE A SIGN EN FINALE par junarnoalg
Voilà qui est fait, la nouvelle est officielle ! L'équipe belge "Make a Sign" va au pays des kangourous défendre son projet dans la catégorie Software Design. http://www.imaginecup.com/CompetitionsContent/Competition/WorldwideFinalists.aspx V...
Cliquez pour lire la suite de l'article par junarnoalg KINECT 1.5 IS OUT !KINECT 1.5 IS OUT ! par Vko
La version 1.5 du Kinect For Microsoft vient tout juste de sortir ! Plein de nouveautés: Tracking de squelette en Near Mode Détection en position assise Détection faciale avec un SDK dédié Documentation et des guideline (enfin) Un out...
Cliquez pour lire la suite de l'article par Vko LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) LES ACTUALITéS DE LA SEMAINE SUR C2I.FR (14 MAI - 20 MAI) par richardc
Mise à jour des Web API du 14 Mai
Réservez dès maintenant votre journée du 20 juin pour le Windows Azure Dev Camp 2012 à Paris
Mise à jour de Team Foundation Service
MechCommander 2 sur Windows 8
Entity Framework 5 Release Candidate e...
Cliquez pour lire la suite de l'article par richardc REACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITERREACTIVE EXTENSIONS : CONSOMMER DES SERVICES AVEC RX PARTIE 3, LES PIèGES à éVITER par Groc
Une mauvaise utilisation de rx lors de l'écriture d'une couche d'accès à des services peut conduire à des cas embarassants avec des erreurs mal gérées, des appels qui ne partent lorsqu'ils le devraient, et même des résultats incorrects . le tout nuis...
Cliquez pour lire la suite de l'article par Groc SHAREPOINT BLOG SITE, PROBLèME D'ARCHIVESSHAREPOINT BLOG SITE, PROBLèME D'ARCHIVES par junarnoalg
Dernièrement, nous avons migré le site
myTIC
vers un nouveau serveur SharePoint 2010. Dans les contenus que nous vouloins récupérer, nous avions un certain nombre de blogs.
Nous avons utilisé les commandes Power...
Cliquez pour lire la suite de l'article par junarnoalg
Forum
UTILISER UN .JSUTILISER UN .JS par zaikoe
Cliquez pour lire la suite par zaikoe
Logiciels
sDEVIS-FACTURES vlPRO (8.1.0.3)SDEVIS-FACTURES VLPRO (8.1.0.3)sDEVIS-FACTURES vlPRO a été mis au point pour les particuliers, créateurs, entrepreneurs, artisa... Cliquez pour télécharger sDEVIS-FACTURES vlPRO 974 Application Server (12.2.4.6)974 APPLICATION SERVER (12.2.4.6)Développez de puissantes applications dans un environnement de 'cloud computing', clusterisé, séc... Cliquez pour télécharger 974 Application Server vPicture (1.4.2.1)VPICTURE (1.4.2.1)Avec vPicture, hébergez vos images facilement et rapidement.
vPicture est un utilitaire simple, ... Cliquez pour télécharger vPicture Easy-Planning (2.2.1.6)EASY-PLANNING (2.2.1.6)Easy-Planning permet de créer des plannings sous la représentation de diagrammes et est adapté au... Cliquez pour télécharger Easy-Planning COM-BACKUP (2.0)COM-BACKUP (2.0)
COM-BACKUP est un logiciel de sauvegarde qui permet de planifier les sauvegardes de vos dossiers ...
Cliquez pour télécharger COM-BACKUP
|