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