Адаптивный центр выравнивания изображений bootstrap 3

Я делаю каталог с помощью Bootstrap 3. При отображении на планшетах изображения продукта выглядят уродливо из-за их небольшого размера (500x500) и ширины 767 пикселей в браузере. Я хочу поместить изображение в центр экрана, но по какой-то причине я не могу. Кто поможет решить проблему?

enter image description here

15 ответов


если вы используете Bootstrap v3.0.1 или больше, вы должны использовать данное решение вместо. Он не переопределяет стили Bootstrap с помощью пользовательского CSS, но вместо этого использует функцию Bootstrap.

мой первоначальный ответ показан ниже для потомков


это приятно легко исправить. Потому что .img-responsive из Bootstrap уже устанавливает display: block, вы можете использовать margin: 0 auto в центр изображения:

.product .img-responsive {
    margin: 0 auto;
}

здесь .center-block класс в Twitter Bootstrap 3 (С V3.0.1), чтобы использовать:

<img src="..." alt="..." class="img-responsive center-block" />

добавить только класс center-block для изображения это также работает с Bootstrap 4:

<img src="..." alt="..." class="center-block" />

Примечание: center-block работает даже тогда, когда img-responsive используется


просто использовать .text-center класс, если вы используете Bootstrap 3.

<div class="text-center">
    <img src="..." alt="..."/>
</div>

Примечание: это не работает с IMG-responsive


Это должно выровнять изображение и сделать его отзывчивым.

<img src="..." class="img-responsive" style="margin:0 auto;"/>

Я бы предложил более "абстрактной" классификации. Добавьте новый класс "img-center", который можно использовать в сочетании С.класс в img-отзывчивый:

// Center responsive images
.img-responsive.img-center {
  margin: 0 auto;
}

вы все еще можете работать с img-responsive без влияния на другие изображения с этим классом стиля.

вы можете предшествовать этому тегу разделом id / div id / class, чтобы определить порядок, в котором это img вложен. Этот обычай img-responsive будет работать только в этой области.

Предположим, у вас есть область HTML, определенная как:

<section id="work"> 
    <div class="container">
        <div class="row">
            <img class="img-responsive" src="some_image.jpg">
        </div>
    </div>
</section>

тогда ваш CSS может быть:

section#work .img-responsive{
    margin: 0 auto;
}

Примечание: этот ответ связан с потенциальным воздействием изменения img-responsive как a целый. Конечно,center-block самое простое решение.


попробуйте это:

.img-responsive{
    display: block;
    height: auto;
    max-width: 100%;
	  margin:0 auto;
}
.Image{
  background:#ccc;
  padding:30px;
}
<div class="Image">
  <img src="http://minisoft.com.bd/uploads/ourteam/rafiq.jpg" class="img-responsive" title="Rafique" alt="Rafique">
</div>

@media (max-width: 767px) {
   img {
     display: table;
     margin: 0 auto;
   }
}

добавить к уже данным ответам, имея img-responsive в сочетании с img-thumbnail устанавливается display: block to display: inline block.


<div class="col-md-12 text-center">
    <img class="img-responsive tocenter" />
</div>

.

<style>
   .tocenter {
    margin:0 auto;
    display: inline;
    }
</style>

попробуйте этот код, он будет работать и для небольших значков с bootstrap 4, потому что нет класса центрального блока bootstrap 4, поэтому попробуйте этот метод, это будет полезно. Вы можете изменить положение изображения, установив .col-md-12 to .col-md-8 или .col-md-4, Это зависит от вас.

<div class="container">
       <div class="row">
          <div class="col-md-12">
            <div class="text-xs-center text-lg-center">
           <img src="" class="img-thumbnail">
           </div>
          </div>
       </div>
  </div>

Вы можете исправить это с определением маржи:0 авто

или вы можете использовать col-md-offset также

<!DOCTYPE html>
<html>
<head>
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="stylesheet" href="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
  <script src="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/js/bootstrap.min.js"></script>
</head>
<style>
.img-responsive{
margin:0 auto;
}
</style>
<body>

<div class="container">
  <h2>Image</h2>
<div class="row">
<div class="col-md-12">
  <p>The .img-responsive class makes the image scale nicely to the parent element (resize the browser window to see the effect):</p>                  
  <img src="http://www.w3schools.com/bootstrap/cinqueterre.jpg" class="img-responsive" alt="Cinque Terre" width="304" height="236"> 
</div>
</div>
</div>

</body>
</html>

более точный способ, применяемый ко всем объектам Booostrap, использующим только стандартные классы, - это не устанавливать верхние и Нижние поля (поскольку изображение может наследовать их от родителя), поэтому я всегда использую:

.text-center .img-responsive {
    margin-left: auto;
    margin-right: auto;
}

Я также сделал суть для этого, поэтому, если какие - либо изменения будут применяться из-за каких-либо ошибок, версия обновления будет всегда здесь: https://gist.github.com/jdrda/09a38bf152dd6a8aff4151c58679cc66


пока самое лучшее решение принять, кажется <img class="center-block" ... />. Но никто не упоминал, как center-block строительство.

возьмите Bootstrap v3.3.6 например:

.center-block {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

значение по умолчанию dispaly на <img> is inline. Значение block отобразит элемент как элемент блока (например,<p>). Она начинается на новой линии и занимает всю ширину. Таким образом, две настройки поля позволяют изображению оставаться в середине горизонтально.