css – 使第二个div首先出现,没有绝对位置或改变html

前端之家收集整理的这篇文章主要介绍了css – 使第二个div首先出现,没有绝对位置或改变html前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的页面分为3个切片,如 JFiddle所示.

在我的完整的源代码中,我有媒体查询来帮助管理移动和桌面之间的大小.当有人以移动模式访问该网站时,徽标应显示在顶部,“项目”应显示在其下方. (我设置显示:我的图片div上没有隐藏)

问题:

我不能改变HTML中的div的位置,否则会打扰我目前的3片布局.绝对定位不是一个选择,因为我的大部分站点已经动态调整大小,我不希望绝对定位来干扰我还没有测试过的分辨率.这意味着计算边际尺寸将不在此问题之内.

所以绝对定位是不允许的,也不是改变div的顺序.我正在寻找的结果将类似于this,没有重新定位div.

我的问题不在于媒体查询,还是如何使用媒体查询来规模移动.我只是问我如何得到我想要的布局我们有限制(没有绝对假设,没有计算边距,没有改变的div顺序).

我看过的其他问题

Reposition div above preceding element – 第一个回答提示重新定位div,我不能做.第二个答案依赖于计算位置,这可能会干扰其他动态调整元素.

Move The First Div Appear Under the Second One in CSS – 建议我使用绝对定位,我不能做

解决方法

FlexBox布局是您的朋友.显示:flex可以用于交换布局上的元素位置.
#container { display:flex; flex-direction: column; text-align:center;}
#items { order: 2 }
#logo { order: 1 }
#picture { display: none; }
<div id="container">
    <div id="items">Items</div>
    <div id="logo">logo</div>
    <div id="picture">Picture</div>
</div>

显示:flex只适用于现代浏览器.检查caniuse.

我的Android手机测试显示它在Firefox和Chrome上工作,但不是在Android的浏览器上.

猜你在找的CSS相关文章