IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Ajouter une class au body quand une div apparait a l'ecran ?


Sujet :

JavaScript

  1. #1
    Candidat au Club
    Homme Profil pro
    Intégrateur Web
    Inscrit en
    Avril 2020
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Avril 2020
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Ajouter une class au body quand une div apparait a l'ecran ?
    Bonjour,

    Tout est plus ou moins dit dans le titre je pense que c'est pas trop compliqué mais je suis trop naze en js :/

    En gros, j'essaie de faire :

    - quand un element (#monelement) devient visible (au scroll) dans le viewport -> addclass au body
    - quand un element (#monelement) devient disparait de l'ecan (au scroll) -> removeclass au body

    Et surtout je suis graphiste/intégrateur html et trop nul en js pour l'ecrire... :/
    J'arrive a le fair een mettant une taille donné pour le scroll mais je ne peux pas pour ce cas de figure car la hauteur de scroll varie d'un page à l'autre...

    MA reconnaissance éternelle à mon sauveur

    ME

  2. #2
    Expert confirmé
    Avatar de Doksuri
    Profil pro
    Développeur Web
    Inscrit en
    Juin 2006
    Messages
    2 467
    Détails du profil
    Informations personnelles :
    Âge : 54
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 467
    Points : 4 658
    Points
    4 658
    Par défaut
    salut, je t'invite a te documenter sur getBoundingClientRect() developer.mozilla.org/fr/docs/Web/API/Element/getBoundingClientRect
    tu auras aussi besoin de la hauteur de ton ecran : developer.mozilla.org/fr/docs/Web/API/Window/innerHeight

  3. #3
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    salut,

    et voir aussi l'excellente contribution de l'excellent Bovino, il y a déjà longtemps:

    https://www.developpez.net/forums/d6...n/#post3932542

    (source que j'ai pompée honteusement ici, même si les inner et les Offset ont tendance à ne pas être standard)

    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    window.addEventListener("wheel", scrollwheel);
    window.addEventListener("scroll", scrollwheel);
     
    function scrollwheel(){
    	if(document.querySelector("#div").offsetTop > window.pageYOffset
    	&& document.querySelector("#div").offsetTop < window.pageYOffset+window.innerHeight){
    		document.body.style.background="blue"
    	}
    	else{
    		document.body.style.background="none"
    	}
    }

  4. #4
    Candidat au Club
    Homme Profil pro
    Intégrateur Web
    Inscrit en
    Avril 2020
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Avril 2020
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Merci beaucoup pour vos réponses !

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [TinyMCE] bouton personnalisé pour ajouter une div avec une classe css
    Par cpalo dans le forum Bibliothèques & Frameworks
    Réponses: 1
    Dernier message: 20/09/2016, 10h03
  2. [CKEditor] CKEditor 3.5 ajoute une div au contenu de l'éditeur
    Par Jaako H. dans le forum Bibliothèques & Frameworks
    Réponses: 1
    Dernier message: 24/06/2011, 16h59
  3. [CSS 2] Ajouter une div à côté d'une autre existante
    Par beegees dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 27/12/2009, 15h17
  4. Ajouter une div au passage sur un lien
    Par oceane751 dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 15/07/2009, 17h50
  5. [DOM] Ajouter une DIV dans une page web
    Par Nulenprogra dans le forum Général JavaScript
    Réponses: 13
    Dernier message: 19/09/2007, 16h48

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo