1

HTML

<div class="element">
    <p>I want to center this element vertically and horizontally.</p>
</div>

CSS

.element
{
    background: #eee;
    border: 1px solid #ccc;
    font-size: 24px;
    margin: 10px;
    padding: 20px;
    position: absolute;
}

jQuery

jQuery(document).ready(function($) {
    var $element = $('.element');

    center();

    $(window).on('resize', function() {
        center();
    });

    function center() {
        var width = $element.outerWidth(true);
        var height = $element.outerHeight(true);

        console.log(width);
        console.log(height);

        $element
            .stop(true)
            .animate({
                top: Math.max(0, ($(window).height() - height) / 2),
                left: Math.max(0, ($(window).width() - width) / 2)
            });
    }
});

问题

如果我调整窗口大小,则元素不会居中,因为outerWidth() 和outerHeight() 是错误的。

刷新后问题消失。

火狐上的测试结果

默认值:元素大小 - 670x134(好)

768x1024:元素大小 - 198x254(错误)- 670x134(刷新后良好)

360x640:元素大小 - 198x254(错误)- 360x182(刷新后良好)

问题

知道为什么会出现此问题以及如何解决吗?

笔记

我不希望元素具有固定的宽度或高度。

4

4 回答 4

3

您的调整大小仅在页面加载时调用,请尝试将您的代码设置为:

jQuery(document).ready(function() {
    center();
});

jQuery(window).resize(function(){
    center();
});

function center() {
    var $element = $('.element');
    var width = $element.outerWidth(true);
    var height = $element.outerHeight(true);

    console.log(width);
    console.log(height);

    $element
    .stop(true)
    .animate({
        top: Math.max(0, ($(window).height() - height) / 2),
        left: Math.max(0, ($(window).width() - width) / 2)
    });
}

在这里提琴

这将在页面加载以及调整大小时调用调整大小。

从较大的窗口调整到较小的窗口时,水平居中元素似乎确实存在延迟,这很可能与动画有关。

也许您可能想要考虑使用非动画方法来使您的元素居中,例如 Abdulla Chozhimadathil 提到的那个。

于 2014-09-25T13:03:36.157 回答
0

请检查小提琴

<div class="container">
    <div class="content">
        content content content 
        <br/>
        moooooooooooooooore content
        <br/>
        another content
    </div>
</div>

html, body {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    display: table;
}
.container {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}
.content {
    background-color: red;
    display: inline-block;
    text-align: left;
}

在这里摆弄

于 2014-09-25T11:03:21.713 回答
0

这是由于,您使用的是 jQuery 动画。因此,在调整窗口大小时,每次都会触发每次调整大小。但在这么短的时间延迟内,动画并没有完成。这样盒子就不会来到中心。但是在调整大小后,它有足够的时间来执行动画。

所以把animate改成direct css,每次resize都可以更新。请检查这个Fiddle

于 2014-09-25T11:38:22.493 回答
0

outerWidth不保证如文档中所述准确。只需编写outerWidth(true),您将获得与.resize()函数相同的确切值。 http://api.jquery.com/outerWidth/

于 2019-06-18T12:37:28.937 回答