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
Patricia Arquetteoriginal
2024-12-12 14:13:14689parcourir

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>
.parent {
  display: table;
}
.header {
  display: inline-block;
  background-color: cornflowerblue;
}
.item {
  display: table-cell;
  padding: 20px;
}
.content {
  background-color: salmon;
  flex-grow: 1;
}

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>
$(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);
});

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!

Déclaration:
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