Maison interface Web tutoriel CSS Pourquoi mon ne rétrécit-il pas comme prévu ? Il semble avoir un problème de min-width: min-content non amovible.

Pourquoi mon ne rétrécit-il pas comme prévu ? Il semble avoir un problème de min-width: min-content non amovible.

Nov 09, 2024 pm 10:44 PM

Why does my  not shrink as expected? It seems to have a non-removable min-width: min-content problem.

ne rétrécit pas comme prévu ; il semble y avoir une largeur minimale inamovible : min-content

problème

J'en ai un soit réduit pour ne jamais être plus large que son parent, même s'il doit tronquer son texte d'affichage. max-width : 100 % devrait faire l'affaire.

Résultats attendus

Ce que je veux après avoir redimensionné la page où <code>sélectionner</code> Son contenu a été coupé

Résultat réel

Ma page actuelle après redimensionnement, avec une barre de défilement

Solution de contournement

Mise à jour (25 septembre 2017)

Le bug de Firefox décrit ci-dessous a été corrigé dans Firefox 53 et le lien vers cette réponse a également été supprimé de Bootstrap retiré du document.

En outre, mes plus sincères excuses aux contributeurs de Mozilla qui ont dû bloquer la suppression du support de -moz-document en partie à cause de cette réponse.

Correction

Dans WebKit et Firefox 53, vous pouvez remplacer la valeur par défaut de min-content simplement en définissant min-width: 0 sur l'ensemble de champs. ¹

Firefox est cependant un peu bizarre en ce qui concerne les ensembles de champs. Pour que cela fonctionne correctement dans les versions antérieures, vous devez modifier la propriété d'affichage du fieldset sur l'une des valeurs suivantes :

  • table-cell (recommandé)
  • table-colonne
  • table-column-group
  • table-footer-group
  • table-header-group
  • table-row
  • table-row-group

Parmi eux, je recommande cellule de table. Table-row et table-row-group vous empêchent de modifier la largeur, tandis que table-column et table-column-group vous empêchent de modifier la hauteur.

Cela (assez légitimement) interrompt le rendu dans IE. Puisque seul Gecko doit faire cela, vous pouvez légitimement masquer cet effet aux autres navigateurs en utilisant l'une des extensions CSS propriétaires de Mozilla, @-moz-document :

@-moz -document préfixe-url() {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">fieldset {
    display: table-cell;
}
Copier après la connexion

}

(Ceci est un jsFiddle Démo. )

Cause

Cela résout le problème, mais si vous êtes comme moi, votre réaction est probablement...

Quoi ?

Il y a une raison, mais ce n’est pas facile à comprendre. Le rendu par défaut de l'élément

fieldset est ridicule et essentiellement impossible à spécifier en CSS. Pensez-y : la bordure du fieldset disparaît là où elle chevauche l'élément de légende, mais l'arrière-plan est toujours visible ! Aucune autre combinaison d'éléments ne peut reproduire cet effet.

Plus important encore, la mise en œuvre regorge de concessions sur les comportements hérités. L'un d'eux est que la largeur minimale d'un ensemble de champs n'est jamais inférieure à la largeur intrinsèque de son contenu. WebKit fournit un moyen de remplacer ce comportement en le spécifiant dans la feuille de style par défaut, mais Gecko² va encore plus loin et applique ce comportement dans le moteur de rendu.

Cependant, les éléments de table internes constituent un type de cadre spécial dans Gecko. Le calcul des contraintes de taille pour les éléments avec ces paramètres de valeur d'affichage s'effectue dans un chemin de code distinct, contournant complètement la largeur minimale appliquée sur l'ensemble de champs.

Encore une fois - Firefox 53 a un correctif de bogue pour ce problème, vous n'avez donc pas besoin de ce correctif si vous ciblez uniquement les versions plus récentes.

Est-il sécuritaire d'utiliser @-moz-document ?

Pour ce problème, c'est sans danger. @-moz-document fonctionne comme prévu dans toutes les versions de Firefox (jusqu'à la 53, où ce bug a été corrigé).

Ce n’est pas un hasard. En partie à cause de cette réponse, le bogue limitant @-moz-document aux feuilles de style utilisateur/UA a été configuré pour s'appuyer d'abord sur la correction du bogue de l'ensemble de champs sous-jacent.

De plus, n'utilisez pas @-moz-document en CSS pour cibler Firefox , malgré le fait que d'autres ressources le fassent. ³

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Créez un formulaire de contact JavaScript avec le cadre Smart Forms Créez un formulaire de contact JavaScript avec le cadre Smart Forms Mar 07, 2025 am 11:33 AM

Créez un formulaire de contact JavaScript avec le cadre Smart Forms

Ajout d'ombres de boîte aux blocs et éléments WordPress Ajout d'ombres de boîte aux blocs et éléments WordPress Mar 09, 2025 pm 12:53 PM

Ajout d'ombres de boîte aux blocs et éléments WordPress

Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques Mar 08, 2025 am 09:45 AM

Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiques

Créer un éditeur de texte en ligne avec l'attribut satisfaistable Créer un éditeur de texte en ligne avec l'attribut satisfaistable Mar 02, 2025 am 09:03 AM

Créer un éditeur de texte en ligne avec l'attribut satisfaistable

Travailler avec GraphQL Caching Travailler avec GraphQL Caching Mar 19, 2025 am 09:36 AM

Travailler avec GraphQL Caching

Faire votre première transition Svelte personnalisée Faire votre première transition Svelte personnalisée Mar 15, 2025 am 11:08 AM

Faire votre première transition Svelte personnalisée

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Mar 04, 2025 am 10:22 AM

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres)

Téléchargement de fichiers avec Multer dans Node.js et Express Téléchargement de fichiers avec Multer dans Node.js et Express Mar 02, 2025 am 09:15 AM

Téléchargement de fichiers avec Multer dans Node.js et Express

See all articles