Cet extrait de code ajoute une barre de progression de lecture à une page Web. La barre représente visuellement la progression du défilement de l'utilisateur dans la zone de contenu principale. Décomposons son fonctionnement et améliorons-le.
Le code tente de calculer la progression en fonction de la position de défilement par rapport à la hauteur totale de l'élément main
. Cependant, il présente plusieurs problèmes :
div
est créé, mais aucune logique de mise à jour de style ou de progression n'est présente.totalHeight
peut être inexact en fonction de la structure de la page. L'utilisation de outerHeight(true)
inclut des marges, ce qui peut ne pas être souhaité. Il ne tient pas non plus compte du contenu dynamique susceptible de modifier la hauteur après le calcul initial.footerHeight
peut entraîner un calcul de progression incorrect si le pied de page est corrigé ou chevauche le contenu principal.Voici une version améliorée qui résout ces problèmes :
<code class="language-javascript">$(document).ready(function() { if ($('body').hasClass('single')) { const progressBar = $('<div id="reading-progress"></div>'); $('header').after(progressBar); let totalHeight = $('main').height(); // Use height() for more accurate calculation let windowHeight = $(window).height(); $(window).on('scroll', function() { let scrollTop = $(this).scrollTop(); let progress = (scrollTop / (totalHeight - windowHeight)) * 100; // Adjust for window height progress = Math.min(progress, 100); // Cap progress at 100% $('#reading-progress').css('width', progress + '%'); }); } });</code>
Ce code amélioré :
div
avec l'ID reading-progress
pour faire office de barre de progression.height()
: Il utilise height()
au lieu de outerHeight(true)
pour un calcul plus précis de la hauteur du contenu principal.$(window).on('scroll', ...)
pour mettre à jour en permanence la largeur de la barre de progression à mesure que l'utilisateur fait défiler.#reading-progress
div. Par exemple :<code class="language-css">#reading-progress { height: 5px; /* Adjust height as needed */ background-color: #007bff; /* Adjust color as needed */ position: fixed; top: 0; left: 0; width: 0; /* Initially 0% width */ z-index: 1000; /* Ensure it's on top */ }</code>
N'oubliez pas d'inclure jQuery dans votre projet pour que ce code fonctionne. Ce code révisé fournit une barre de progression de lecture plus robuste et plus précise. D'autres améliorations pourraient inclure la gestion des cas extrêmes et l'ajout d'un style plus sophistiqué.
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!