Maison > interface Web > js tutoriel > Comment déterminer le pourcentage de défilement vertical entre navigateurs en JavaScript ?

Comment déterminer le pourcentage de défilement vertical entre navigateurs en JavaScript ?

Mary-Kate Olsen
Libérer: 2024-10-18 17:15:29
original
338 Les gens l'ont consulté

How Do I Determine the Vertical Scroll Percentage Cross-Browser in JavaScript?

Méthode multi-navigateurs pour déterminer le pourcentage de défilement vertical en JavaScript

Dans le développement Web, il devient souvent nécessaire de déterminer le pourcentage de défilement vertical barre de défilement parcourue par un utilisateur. La méthode suivante fournit une solution multi-navigateurs à ce problème.

Approche basée sur les fonctions

En utilisant des éléments HTML et des objets de document, nous pouvons calculer le pourcentage de défilement comme suit :

<code class="javascript">function getScrollPercent() {
    var h = document.documentElement, 
        b = document.body,
        st = 'scrollTop',
        sh = 'scrollHeight';
    return (h[st]||b[st]) / ((h[sh]||b[sh]) - h.clientHeight) * 100;
}</code>
Copier après la connexion

Alternative jQuery

Pour ceux qui préfèrent jQuery, un écouteur d'événement peut être utilisé :

<code class="javascript">$(window).on('scroll', function(){
  var s = $(window).scrollTop(),
      d = $(document).height(),
      c = $(window).height();

  var scrollPercent = (s / (d - c)) * 100;
  
  console.log(scrollPercent);
})</code>
Copier après la connexion

Limitations

Notez que cette méthode peut ne pas afficher avec précision 100 % sur les navigateurs mobiles modernes en raison de la fonctionnalité de masquage automatique lors du défilement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal