gpt4 book ai didi

javascript - 使用 .outerWidth()/.outerHeight() 将带有边距/填充的元素居中。函数返回不同的边距和填充值

转载 作者:行者123 更新时间:2023-11-29 23:55:48 26 4
gpt4 key购买 nike

我试图通过计算父元素和子元素的宽度和高度的差异并将差异用作边距或填充来使元素在其父元素中横向和垂直居中。

我正在使用这个公式计算必要的空间:

($outerElement.outerWidth() - $innerElement.outerWidth() / 2;
($outerElement.outerHeight() - $innerElement.outerHeight() / 2;

然后我使用一个函数遍历一组方向,该函数允许我使用函数参数更改应用于子元素的 css。基本上,该功能允许我选择是否要使用边距或填充。

问题

虽然我的代码返回了顶部、右侧、左侧和底部的预期值,但它没有使用填充来实现吗?知道是什么原因造成的吗?

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

最佳答案

发生这种情况是因为您将 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>

关于javascript - 使用 .outerWidth()/.outerHeight() 将带有边距/填充的元素居中。函数返回不同的边距和填充值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41739592/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com