Центрирование элементов с полем / отступом с помощью.outerWidth()/. OuterHeight(). Функция возвращает разные значения для полей и отступов
Я пытаюсь центрировать элементы как по горизонтали, так и по вертикали в их родительских элементах, вычисляя разницу в ширине и высоте родительского и дочернего элемента и используя разницу в качестве полей или отступов.
Я рассчитываю необходимое пространство по этой формуле:
($outerElement.outerWidth() - $innerElement.outerWidth() / 2;
($outerElement.outerHeight() - $innerElement.outerHeight() / 2;
Затем я перебираю массив направлений, используя функцию, которая позволяет мне изменять css, примененную к дочернему элементу, используя аргумент функции. По сути, функция позволяет мне выбирать, хочу ли я использовать поля или отступы.
Эта проблема
Хотя мой код возвращает ожидаемые значения для top, right, left и bottom, он не делает это, используя padding? Есть идеи, что вызывает это?
HTML
<div id="demo" class="outer">
<div class="inner">
</div>
</div>
CSS
html {
box-sizing: border-box;
}
*, *:before, *:after {
box-sizing: inherit;
}
.outer {
width:500px;
height:200px;
border:1px solid black;
margin:20px;
}
.inner {
width:100px;
height:100px;
background-color:grey;
}
JAVASCRIPT
var $outer = $(".outer");
var $inner = $(".inner");
var getSpace = function(axis) {
if (axis.toLowerCase() == "x") {
return ($outer.outerWidth() - $inner.outerWidth()) / 2;
} else if (axis.toLowerCase() == "y") {
return ($outer.outerHeight() - $inner.outerHeight()) / 2;
}
}
var renderStyle = function(spacingType) {
$.each(["top", "right", "bottom", "left"], function(index, direction) {
if (direction == "top" || direction == "bottom") {
$inner.css(spacingType + "-" + direction, getSpace("y"));
console.log(getSpace("y"));
} else if (direction == "right" || direction == "left") {
$inner.css(spacingType + "-" + direction, getSpace("x"));
console.log(getSpace("x"));
}
});
};
renderStyle("padding");
CODEPEN LINK - ссылка
1 ответ
Это происходит потому, что вы устанавливаете padding
во внутреннюю коробку вместо внешней.
Вы можете установить его с помощью if
состояние.
Вот рабочий фрагмент. Вы можете проверить это для обоих renderStyle("margin");
а также renderStyle("padding");
var $outer = $(".outer");
var $inner = $(".inner");
var getSpace = function(axis) {
if (axis.toLowerCase() == "x") {
return ($outer.outerWidth() - $inner.outerWidth()) / 2;
}
else if (axis.toLowerCase() == "y") {
return ($outer.outerHeight() - $inner.outerHeight()) / 2;
}
}
var renderStyle = function(spacingType) {
var xi = getSpace("x");
var yi = getSpace("y");
if (spacingType == "padding") {
var $ei = $outer;
} else if (spacingType == "margin") {
var $ei = $inner;
}
$.each(["top", "right", "bottom", "left"], function(index, direction) {
if (direction == "top" || direction == "bottom") {
$ei.css(spacingType + "-" + direction, yi);
}
else if (direction == "right" || direction == "left") {
$ei.css(spacingType + "-" + direction, xi);
}
});
};
renderStyle("padding");
.outer {
width:400px;
height:200px;
border:1px solid black;
margin:20px;
box-sizing:border-box;
}
.inner {
width:100px;
height:100px;
background-color:grey;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="demo" class="outer">
<div class="inner">
</div>
</div>