在网格系统中使用空 div

发布于 2025-01-07 13:46:20 字数 3855 浏览 1 评论 0原文

我正在使用 1140 网格系统,有一个基本问题:如果您希望元素宽度小于 12 列,是否需要使用空 div 作为“间隔符”?

这是我想要实现的模型:

在此处输入图像描述

基本上,我希望页脚仅位于主页面下方区域,但在其自己的行中。我能看到做到这一点的唯一方法是使用 div 作为“间隔符”将页脚缩进到我想要的位置。是这样完成的吗?

这是代码(您需要将预览屏幕放大才能看到发生了什么): http:// jsfiddle.net/saltcod/87DZC/

<link rel="stylesheet" href="https://raw.github.com/robertcedwards/HTML-5-Boilerplate-1140-Grid/master/css/1140.css" type="text/css" media="screen" />

<div id="main">
<h1 class="site-title">Site Title</h1>
    <div class="container">
        <div class="row"> 
            <div id="sidebar" class="threecol">
                <h4> Sidebar - Three cols</h4>
                <ul> 
                    <li> Item one</li>
                    <li> Item two</li>
                    <li> Item three</li>
                    <li> Item four</li>
                    <li> Item five</li>
            </div>
            <div id="primary" class="ninecol last">
                <h3>Nine columns</h3>
                <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse vel lectus non nisi pellentesque porta sed vel ante. Aliquam ut elit nulla, ac fermentum diam. Donec convallis dui in felis bibendum mollis. Quisque egestas purus libero, ac vehicula tortor. Sed tristique est sed libero pulvinar nec luctus metus vulputate. Etiam ac tempor nunc. Morbi sit amet neque lacus, ac lacinia nisl. Nullam imperdiet ornare sem, non viverra ipsum hendrerit id. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras vel leo nisl. Ut bibendum ornare urna eget lacinia.</p>

                <p>Aliquam ante lectus, ornare a sollicitudin tincidunt, convallis a magna. Sed fermentum lacus id nisl vestibulum interdum. Ut mattis justo in mi vulputate porttitor. Proin sagittis, urna quis blandit semper, velit nisi aliquet dui, et placerat leo purus a erat. Donec congue, elit a eleifend facilisis, lectus sapien placerat augue, in feugiat ante purus sodales libero. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean eget lacus sed enim euismod faucibus. Pellentesque facilisis arcu sed leo gravida a ultricies nisi cursus. Quisque venenatis mollis ligula sed semper. Nullam ac sem purus, non tincidunt velit. In hendrerit, odio sit amet tempus pharetra, libero orci suscipit tellus, eu mollis augue dui a nulla. Vivamus dignissim elit sit amet est mollis sed aliquet lorem posuere. Nulla varius purus quis elit pellentesque et auctor nunc gravida. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Sed nibh erat, aliquet a luctus vel, pulvinar nec neque.</p>

                 <h2> If I want three blocks inside #primary, that's easy: </h2>
                 <div class="fourcol bottom">A</div>
                <div class="fourcol bottom">B</div>
                <div class="fourcol bottom last">C</div>

        </div> <!-- [ .row ] -->

        <footer class="row twelvecol">
            <h3> But if I want three blocks in my footer, I need to 'indent' it with an empty div?</h3>
            <div class="threecol empty bottom"> [ empty div ]</div>
            <div class="threecol bottom">A</div>
            <div class="threecol bottom">B</div>
            <div class="threecol bottom last">C</div>
            <p> Isn't this a bit like using a spacer gif in a table layout? </p> 
        </footer>
    </div>
</div>

I'm using the 1140 grid system and have a basic question: Do you need to use empty divs as "spacers" if you want an element to be less than 12 cols wide?

Here's the mockup I'm looking to achieve:

enter image description here

Basically, I want to footer to be only underneath the primary area, but in its own row. The only way I can see to do this is to use a div as a "spacer" to indent the footer to where I want it. Is this how its done?

Here's the code (you'll need to make the preview screen large to see what's going on): http://jsfiddle.net/saltcod/87DZC/

<link rel="stylesheet" href="https://raw.github.com/robertcedwards/HTML-5-Boilerplate-1140-Grid/master/css/1140.css" type="text/css" media="screen" />

<div id="main">
<h1 class="site-title">Site Title</h1>
    <div class="container">
        <div class="row"> 
            <div id="sidebar" class="threecol">
                <h4> Sidebar - Three cols</h4>
                <ul> 
                    <li> Item one</li>
                    <li> Item two</li>
                    <li> Item three</li>
                    <li> Item four</li>
                    <li> Item five</li>
            </div>
            <div id="primary" class="ninecol last">
                <h3>Nine columns</h3>
                <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse vel lectus non nisi pellentesque porta sed vel ante. Aliquam ut elit nulla, ac fermentum diam. Donec convallis dui in felis bibendum mollis. Quisque egestas purus libero, ac vehicula tortor. Sed tristique est sed libero pulvinar nec luctus metus vulputate. Etiam ac tempor nunc. Morbi sit amet neque lacus, ac lacinia nisl. Nullam imperdiet ornare sem, non viverra ipsum hendrerit id. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras vel leo nisl. Ut bibendum ornare urna eget lacinia.</p>

                <p>Aliquam ante lectus, ornare a sollicitudin tincidunt, convallis a magna. Sed fermentum lacus id nisl vestibulum interdum. Ut mattis justo in mi vulputate porttitor. Proin sagittis, urna quis blandit semper, velit nisi aliquet dui, et placerat leo purus a erat. Donec congue, elit a eleifend facilisis, lectus sapien placerat augue, in feugiat ante purus sodales libero. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenean eget lacus sed enim euismod faucibus. Pellentesque facilisis arcu sed leo gravida a ultricies nisi cursus. Quisque venenatis mollis ligula sed semper. Nullam ac sem purus, non tincidunt velit. In hendrerit, odio sit amet tempus pharetra, libero orci suscipit tellus, eu mollis augue dui a nulla. Vivamus dignissim elit sit amet est mollis sed aliquet lorem posuere. Nulla varius purus quis elit pellentesque et auctor nunc gravida. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Sed nibh erat, aliquet a luctus vel, pulvinar nec neque.</p>

                 <h2> If I want three blocks inside #primary, that's easy: </h2>
                 <div class="fourcol bottom">A</div>
                <div class="fourcol bottom">B</div>
                <div class="fourcol bottom last">C</div>

        </div> <!-- [ .row ] -->

        <footer class="row twelvecol">
            <h3> But if I want three blocks in my footer, I need to 'indent' it with an empty div?</h3>
            <div class="threecol empty bottom"> [ empty div ]</div>
            <div class="threecol bottom">A</div>
            <div class="threecol bottom">B</div>
            <div class="threecol bottom last">C</div>
            <p> Isn't this a bit like using a spacer gif in a table layout? </p> 
        </footer>
    </div>
</div>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

梦言归人 2025-01-14 13:46:20

这不是有点像在表格布局中使用间隔 gif 吗?

是的,本质上 div 会创建您想要的空间。使用 CSS 网格框架时,通常会使用带有适当列类的空 div 来相应地分隔内容。当然,您可以想出涉及相对定位等的替代解决方案,但为什么会让事情变得复杂呢。最后一段代码应该看起来像这样。

    <footer class="row twelvecol">
        <div class="threecol first"></div>           
        <div class="threecol bottom">A</div>
        <div class="threecol bottom">B</div>
        <div class="threecol bottom last">C</div>
    </footer>

Isn't this a bit like using a spacer gif in a table layout?

Yes essentially the div will create the space you intended it to make. When using CSS grid frameworks, it's common to use empty divs with the appropriate column class in order to space things accordingly. Of course you can come up with alternate solutions involving relative positioning, etc, but why complicate matters. The last bit of code should look something like this.

    <footer class="row twelvecol">
        <div class="threecol first"></div>           
        <div class="threecol bottom">A</div>
        <div class="threecol bottom">B</div>
        <div class="threecol bottom last">C</div>
    </footer>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文