Maison > interface Web > tutoriel CSS > Comment JavaScript peut-il détecter le débordement de contenu d'un élément HTML, même avec « overflow : visible » ?

Comment JavaScript peut-il détecter le débordement de contenu d'un élément HTML, même avec « overflow : visible » ?

Patricia Arquette
Libérer: 2024-12-24 21:27:40
original
196 Les gens l'ont consulté

How Can JavaScript Detect HTML Element Content Overflow, Even with `overflow: visible`?

Vérification du débordement de contenu dans les éléments HTML à l'aide de JavaScript

Lorsque le contenu d'un élément HTML dépasse ses dimensions définies, cela peut entraîner un débordement. Bien que le débordement visible puisse être vérifié à l'aide de vérifications standard, la vérification du débordement avec la propriété "overflow: visible" peut poser un défi.

Solution JavaScript

Pour en tenir compte , une fonction JavaScript peut être employé :

function checkOverflow(el) {
   var curOverflow = el.style.overflow;

   // If overflow is 'visible' or not set
   if (!curOverflow || curOverflow === "visible") {
      // Temporarily set overflow to 'hidden'
      el.style.overflow = "hidden";
   }

   var isOverflowing = el.clientWidth < el.scrollWidth ||
                       el.clientHeight < el.scrollHeight;

   // Restore original overflow style
   el.style.overflow = curOverflow;

   return isOverflowing;
}
Copier après la connexion

Utilisation :

Passez l'élément HTML en question en paramètre à la fonction checkOverflow pour déterminer si son contenu déborde. La fonction retournera vrai s'il y a débordement, sinon elle retournera faux.

Compatibilité :

Cette solution a été testée dans Firefox 3 et 40, Internet Explorer 6 et Chrome 0.2.149.30.

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.cn
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