Bootstrap: comment changer la largeur du conteneur?


127

J'ai utilisé Twitter Bootstrap pour développer un site Web avec la classe de conteneur fixe, mais le client souhaite maintenant que le site Web ait une largeur de 1000 pixels et non 1170 pixels. Je n'utilise pas les fichiers .less.

Existe-t-il un moyen rapide de résoudre ce problème?


Reportez-vous à la réponse ici , je pense que votre problème sera résolu par un violon fixe uniquement dans cette réponse.
prem

@prem, tx mais je n'obtiens pas l'exemple car il n'utilise aucune des classes d'amorçage comme span's ou container. Tout ce dont je pense avoir besoin pour ce projet est de définir le maximum du conteneur à 940px avec le bootstrap réactif.
alex

Réponses:


76

Accédez à la section Personnaliser sur le site Bootstrap et choisissez la taille que vous préférez. Vous devrez définir @gridColumnWidthet @gridGutterWidthvariables.

Par exemple: @gridColumnWidth = 65pxet @gridGutterWidth = 20pxrésultats sur une 1000pxmise en page.

Puis téléchargez-le.


on ne peut pas atteindre le conteneur exact de 1000px en changeant les variables gridColumnWidth et gridGutterWidth ... parce que (12 * (gridColumnWidth) + 12 (gridGutterWidth)) ne vaut pas 1000. Et donc seulement j'ai donné cette solution. Est-ce exact?
prem

15
Théoriquement, il existe des combinaisons infinies qui correspondent à 1000 px. Un exemple: 12 * 65 + 11 * 20 = 1000 (il n'y a que 11 gouttières entre les colonnes).
albertedevigo le

hein! Je n'ai vraiment pas reconnu la chose simple ... de toute façon, la vôtre était la solution appropriée.
prem

Merci pour votre message, cela a été utile;) Juste une note: il y aurait en pratique exactement 7 solutions utilisant des pixels complets pour une largeur de 1000 pixels. (largeurs de colonne 10, 21, 32, 43, 54, 65 et 76)
dfherr

@dfherr Je ne sais pas ce que vous voulez dire exactement quand vous dites "pratiquement", mais gardez à l'esprit que CSS prend en charge les valeurs décimales pour les pixels. Par conséquent, il existe des solutions infinies. w3.org/TR/CSS21/syndata.html#length-units
albertedevigo

232

Voici la solution:

@media (min-width: 1200px) {
    .container{
        max-width: 970px;
    }
}

L'avantage de faire cela, par rapport à la personnalisation de Bootstrap comme dans la réponse de @ Bastardo , est que cela ne change pas le fichier Bootstrap. Par exemple, si vous utilisez un CDN, vous pouvez toujours télécharger la plupart de Bootstrap à partir du CDN.


10
La plupart des réponses négligent CDN. Votre réponse est une solution parfaite.
Charles Watson

2
C'est parfait pour les personnes qui utilisent le CDN. Modifier le LESS (quand 4 arrive, le SASS) au moment de la construction est parfait pour les personnes hébergeant leur propre CSS Bootstrap. Cependant, la modification d'un LESS (ou SASS) personnalisé importé après celui fourni signifie que vous pouvez mettre à niveau le LESS sous-jacent sans (généralement) faire une différence.
Greg Pettit

2
Je sais que c'est vraiment tard, mais étant donné que les conteneurs ont tendance à être plus gros maintenant si vous ajoutez width: auto au code ci-dessus, vous pouvez rendre les conteneurs plus grands que leur 1170 maximum.
Rick Calder

C'est ce que je cherchais. Je vous remercie.
tedebus

20

Vous en attachez un derrière le dos en disant que vous n'utiliserez pas les fichiers LESS. J'ai construit mon premier thème Twitter Bootstrap en utilisant 2.0, et j'ai tout fait en CSS - créer un fichier override.css. Il a fallu des jours pour que les choses fonctionnent correctement.

Maintenant, nous avons 3.0. Laissez-moi vous assurer qu'il faut moins de temps pour apprendre MOINS, ce qui est assez simple si vous êtes à l'aise avec CSS, que de faire tous ces remplacements CSS fous. Faire des changements comme celui que vous souhaitez est un jeu d'enfant.

Dans Bootstrap 3.0, la classe conteneur contrôle la largeur et tous les styles contenus s'ajustent pour remplir le conteneur. Les variables de largeur du conteneur se trouvent au bas du fichier variables.less.

// Container sizes
// --------------------------------------------------

// Small screen / tablet
@container-tablet:            ((720px + @grid-gutter-width));

// Medium screen / desktop
@container-desktop:           ((940px + @grid-gutter-width));

// Large screen / wide desktop
@container-lg-desktop:        ((1020px + @grid-gutter-width));

Certains sites n'ont pas assez de contenu pour remplir l'affichage 1020 ou vous voulez un cadre plus étroit pour des raisons esthétiques. Parce que BS utilise une grille de 12 colonnes, j'utilise un multiple comme 960.


4
Fonctionne, mais: les noms des variables sont @container-sm, @container-mdet @container-lg(maintenant)
Andreas Dolk

1
@Bastardo joli nom +1
Ömer An

18

@mcbjam a déjà donné cette réponse, mais voici un peu plus d'explications.

Vous pouvez facilement effectuer la modification en utilisant une requête multimédia dans votre fichier CSS sans télécharger BS. Je viens de faire cela et cela fonctionne à merveille.

La valeur "min-width" de la requête multimédia indiquera à CSS de changer la largeur de votre conteneur à 1000px uniquement sur les écrans plus grands que 1200px (ou quelle que soit la largeur que vous choisissez d'y inclure). Cela préserve la réactivité de votre site, donc lorsque la taille de l'écran passe en dessous de cette valeur (moniteur plus petit, tablette, smartphone, etc.), votre site s'ajustera toujours pour s'adapter aux écrans plus petits.

@media (min-width: 1200px) {
  .container {
    width: 1000px;
  }
}

13

Pour bootstrap 4 si vous utilisez Sass, voici la variable à modifier

// Grid containers
//
// Define the maximum width of `.container` for different screen sizes.

$container-max-widths: (
  sm: 540px,
  md: 720px,
  lg: 960px,
  xl: 1140px
) !default;

Pour remplacer cette variable, j'ai déclaré $ container-max-widths sans! Default dans mon fichier .sass avant d'importer le bootstrap.

Remarque: je n'avais besoin que de changer la valeur xl, donc je ne me souciais pas de penser aux points d'arrêt.


12

Définissez votre propre classe de conteneur de contenu avec la propriété de largeur 1000px, puis utilisez la classe de boostrap de fluide conteneur au lieu de conteneur.

Fonctionne mais n'est peut-être pas la meilleure solution.


6

Utilisez un sélecteur de wrapper et créez un conteneur qui a une largeur de 100% à l'intérieur de ce wrapper pour encapsuler la page entière.

<style>#wrapper {width: 1000px;} 
#wrapper .container {max-width: 100%; display: block;}</style>
<body>
<div id="wrapper">
  <div class="container">
    <div class="row">....

Maintenant, la largeur maximale est fixée à 1000px et vous n'avez pas besoin de moins ou de sass.


0

Tailles des conteneurs

@container-large-desktop
(1140px + @grid-gutter-width) -> (970px + @grid-gutter-width)

dans la section Tailles des conteneurs, passez 1140à970

J'espère que cela vous aidera.


merci pour votre correct. lien pour personnaliser le bootstrap: https://getbootstrap.com/docs/3.4/customize/


-3

Ajoutez ces morceaux de CSS dans votre style css. Il est préférable d'ajouter ceci après l'ajout du fichier css d'amorçage afin de l'écraser.

html, body {
 height: 100%;
 max-width: 100%;
 overflow-x: hidden;
}`
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.