Я хочу сказать, что я все пробовал, но я отказываюсь верить, что это правда. Я пытаюсь вертикально выравнивать изображение внутри div. Хотя это выглядело так, как будто это сработало, я заметил, что над изображением было больше места, чем ниже.Контексты вертикального выравнивания с рамкой поля
После некоторой отладки, я обнаружил, что проблема была box-sizing: border-box
. Но поскольку я использую Bootstrap (и, похоже, он полагается на него), я не могу его изменить.
См. Мой фрагмент ниже. Нажмите «Toggle box-sizing», чтобы включить или отключить размер окна.
var toggled = false;
$('#toggle').on('click', function() {
\t \t if (!toggled) {
\t \t $('*').css('box-sizing', 'border-box');
toggled = true;
} else {
\t \t $('*').css('box-sizing', 'initial');
toggled = false;
}
});
.left-sidebar {
width: 180px;
background-color: #34495e;
}
.left-sidebar .user-menu {
height: 80px;
position: relative;
padding: 0 15px;
color: #fff;
line-height: 80px;
border-bottom: 2px solid #3d566e;
}
.left-sidebar .user-menu img {
vertical-align: middle;
border-radius: 50%;
}
.left-sidebar .user-menu .user-info {
margin-left: 5px;
font-size: 16px;
font-weight: 300;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button id="toggle">Toggle box-sizing</button>
<nav class="left-sidebar">
<div class="user-menu">
<img src="https://placehold.it/50x50">
<span class="user-info">Someone</span>
</div>
</nav>
<!-- .left-sidebar -->
Я надеюсь, что вы, ребята, можете помочь мне.
Я думаю, что это не коробчатую проклейки. Можете ли вы играть с .left-sidebar .user-menu class line-height: 78px – San
@Paulie_D Я понимаю, не думал об использовании Stack Snippet. Обновлен мой вопрос, чтобы заменить JSFiddle. – SomeCode
@San Я пробовал играть с высотой линии, но мне пришлось установить ее в 75px странно, чтобы изображение было сосредоточено. – SomeCode