Pourquoi les éléments flexibles ne sont-ils pas réduits au-delà de la taille du contenu ?
P粉242126786
P粉242126786 2023-08-27 16:35:08
0
2
443

J'ai 4 colonnes Flexbox et tout fonctionne bien, mais lorsque j'ajoute du texte à la colonne et que je la règle sur une grande taille de police, la colonne est plus large qu'elle ne devrait l'être en raison de la propriété Flex.

J'ai essayé d'utiliser word-break:break-word et cela m'a aidé, mais lorsque j'ai redimensionné la colonne à une très petite largeur, les lettres du texte étaient divisées en plusieurs lignes (une lettre par ligne), mais la largeur de la colonne ne sera pas inférieure à la taille d'une lettre.

Regarder cette vidéo (Au départ, la première colonne est la plus petite, mais lorsque je redimensionne la fenêtre, c'est la colonne la plus large. Je veux juste toujours respecter les paramètres Flex ; taille Flex 1:3:4:4)

Je sais, réduire la taille de la police et le remplissage des colonnes serait utile... mais existe-t-il une autre solution ?

Je ne peux pas utiliser overflow-x:hidden.

JSFiddle


.container { affichage : flexible ; largeur : 100% } .col { hauteur minimale : 200 px ; remplissage : 30 px ; saut de mot : briser le mot } .col1 { flexion : 1 ; fond : orange ; taille de la police : 80px } .col2 { flexion : 3 ; fond : jaune } .col3 { flexion : 4 ; fond : bleu ciel } .col4 { flexion : 4 ; fond : rouge } 
Lorem ipsum dolor
Lorem ipsum dolor
Lorem ipsum dolor
Lorem ipsum dolor


P粉242126786
P粉242126786

répondre à tous (2)
P粉156532706

Je trouve que Flex et Grid me dérangent depuis des années, alors voici ce que je suggère :

* { min-width: 0; min-height: 0; }

Ensuite, si vous avez besoin de ce comportement, utilisez simplementmin-width: automin-height: auto.

En fait, vous pouvez également ajouter des tailles de boîtes pour rendre toutes les mises en page plus logiques :

* { box-sizing: border-box; min-width: 0; min-height: 0; }

Est-ce que quelqu'un sait s'il y a des conséquences étranges ? Je n'ai eu aucun problème depuis quelques années en utilisant un mélange des méthodes ci-dessus. En fait, je ne vois aucun cas où je voudrais mettre en page le contenu vers l'extérieur dans le Flex/Grid, plutôt que de le mettre en page depuis le Flex/Grid vers l'intérieur dans le contenu --- bien sûr, s'ils existent, ils sont rares. . Cela ressemble donc à un mauvais défaut. Mais peut-être qu'il me manque quelque chose ?

    P粉043295337

    Taille minimale automatique pour les projets Flex

    Vous rencontrez les paramètres par défaut de Flexbox.

    Les éléments Flex ne peuvent pas être plus petits que la taille de leur contenu le long de l'axe principal.

    La valeur par défaut est...

    • 最小宽度:自动
    • 最小高度:自动

    ... éléments flexibles pour les directions de ligne et de colonne respectivement.

    Vous pouvez remplacer ces valeurs par défaut en définissant l'élément flexible sur :

    • 最小宽度:0
    • 最小高度:0
    • 溢出:隐藏(或任何其他值,可见Sauf)

    Spécifications Flexbox

    À propos deautovaleur...

    En d'autres termes :

      Applicable lorsque
    • min-width: automin-height: auto默认值仅在overflow可见.
    • Sioverflow值不可见,则min-size属性的值为0.
    • Par conséquent,overflow: hide可以替代min-width: 0min-height: 0.

    Aussi...


    Vous avez appliqué min-width: 0 mais le projet ne rétrécit toujours pas ?

    Conteneurs flexibles imbriqués

    Si vous travaillez avec des projets Flex sur plusieurs niveaux de la structure HTML, vous souhaiterez peut-être remplacer la valeur par défautmin-width: auto/min-height: auto code> sur les projets de niveau supérieur.

    Fondamentalement, avoir un élément Flex de niveau supérieur avecmin-width: auto的更高级别的 Flex 项目可以防止使用min-width: 0empêche les éléments imbriqués ci-dessous avec

    min-width: 0 de rétrécir.

    Exemple :
    • Les articles flexibles ne rétrécissent pas plus petits que leur contenu
    • Faites en sorte que l'enfant s'adapte au parent
    • Les propriétés CSS vides peuvent causer des problèmes avec Flex

    Instructions de rendu du navigateur

    Démo modifiée

    .container { display: flex; } .col { min-height: 200px; padding: 30px; word-break: break-word } .col1 { flex: 1; background: orange; font-size: 80px; min-width: 0; /* NEW */ } .col2 { flex: 3; background: yellow } .col3 { flex: 4; background: skyblue } .col4 { flex: 4; background: red }
    Lorem ipsum dolor
    Lorem ipsum dolor
    Lorem ipsum dolor
    Lorem ipsum dolor
      Derniers téléchargements
      Plus>
      effets Web
      Code source du site Web
      Matériel du site Web
      Modèle frontal
      À propos de nous Clause de non-responsabilité Sitemap
      Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!