Maison > interface Web > tutoriel CSS > Comment puis-je égaliser dynamiquement les hauteurs des en-têtes de cartes qui ne sont pas des enfants directs de leur conteneur parent à l'aide de CSS ou jQuery ?

Comment puis-je égaliser dynamiquement les hauteurs des en-têtes de cartes qui ne sont pas des enfants directs de leur conteneur parent à l'aide de CSS ou jQuery ?

Patricia Arquette
Libérer: 2024-12-12 14:13:14
original
686 Les gens l'ont consulté

How can I dynamically equalize the heights of card headers that are not direct children of their parent container using CSS or jQuery?

Égalisation dynamique des en-têtes de cartes à l'aide de CSS ou jQuery

Problème :

Faire correspondre les hauteurs de en-têtes de carte qui ne sont pas des enfants directs du conteneur parent, malgré les changements de contenu et l'écran réactif tailles.

Solution CSS :

Cette approche exploite la propriété de bloc en ligne et les fonctionnalités d'ajustement automatique de la hauteur des cellules du tableau HTML pour égaliser dynamiquement les hauteurs d'en-tête.

<table class="parent">
  <thead>
    <tr>
      <th class="header">Header 1</th>
      <th class="header">Header 2</th>
      <th class="header">Header 3</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td class="item">
        <div class="content">Content for Header 1</div>
      </td>
      <td class="item">
        <div class="content">Content for Header 2</div>
      </td>
      <td class="item">
        <div class="content">Content for Header 3</div>
      </td>
    </tr>
    <tr>
      <td class="item">
        <div class="content">Content for Header 1</div>
      </td>
      <td class="item">
        <div class="content">Content for Header 2, with extra wrapping</div>
      </td>
      <td class="item">
        <div class="content">Content for Header 3</div>
      </td>
    </tr>
  </tbody>
</table>
Copier après la connexion
.parent {
  display: table;
}
.header {
  display: inline-block;
  background-color: cornflowerblue;
}
.item {
  display: table-cell;
  padding: 20px;
}
.content {
  background-color: salmon;
  flex-grow: 1;
}
Copier après la connexion

Solution jQuery :

Cette solution emploie jQuery pour définir des hauteurs égales pour les en-têtes et peut être personnalisé en fonction des exigences de ligne ou de colonne.

<div class="row">
  <div class="col item">
    <div class="header">Header 1</div>
    <div class="content">Content for Header 1</div>
  </div>
  <div class="col item">
    <div class="header">Header 2</div>
    <div class="content">Content for Header 2</div>
  </div>
  <div class="col item">
    <div class="header">Header 3</div>
    <div class="content">Content for Header 3</div>
  </div>
</div>
Copier après la connexion
$(function() {
  // Preload header elements
  var $headers = $('.header');

  // Set equal height on all headers
  function setEqualHeight() {
    var maxHeight = 0;
    $headers.each(function() {
      maxHeight = Math.max(maxHeight, $(this).outerHeight());
    });
    $headers.css('height', maxHeight + 'px');
  }

  // Set equal height per row
  function setEqualHeightPerRow() {
    var previousTop = 0;
    var height = 0;
    $headers.each(function() {
      var currentTop = $(this).offset().top;
      if (currentTop > previousTop) {
        $(this).css('height', height + 'px');
        previousTop = currentTop;
        height = 0;
      }
      height = Math.max(height, $(this).outerHeight());
    });
    $(this).css('height', height + 'px');
  }

  // Run on load and resize
  setEqualHeight();
  $(window).resize(setEqualHeight);
});
Copier après la connexion

Ces solutions fournissent une correspondance dynamique et réactive des hauteurs d'en-tête, garantissant la cohérence de la conception de l'interface utilisateur, quel que soit le contenu ou taille de l'écran.

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