html - 为什么我的 2 列纯 CSS 布局不起作用?

标签 html css meteor stylus yui-pure-css

我正在尝试创建一个简单的 Meteor Web 应用程序,但我已经在努力生成通过 Pure responsive grid 定义的工作 2 列布局.下面的屏幕截图显示了该问题;标题应该是一行两列,而不是两(行)并且“侧边栏内容”应该在“Ace Editor Demo”左侧的列中:

enter image description here

您也可以访问 live version我的应用程序自己看看问题。此外,我已经在 github 上发布了该元素。 .

如果有人能指出为什么我预期的 2 列布局没有按预期工作,我会非常高兴。我已经使用 Chromium 28.0.1500.71 和 Firefox 23.0 进行了测试。

代码

样式

这是应用程序的样式表(写在 Stylus 中):

menu-background = #272F32
menu-color = #DAEAEF
padding-horizontal = 3em
padding-vertical = 1em
padding-top = 35px

.content
    border-radius: 10px
    margin-top 39px
    background-color white

    padding-left 0px
    padding-right 0px
    // padding-top padding-vertical
    padding-bottom padding-vertical

    .content-ribbon
        background-color white
        //padding-left padding-horizontal
        //padding-right padding-horizontal

    #sidebar
        padding-left: 20px
        padding-top: padding-top

    #editor-container
        padding-top: padding-top
        border-left: 1px solid
        padding-left: padding-horizontal
        height: 600px

        & > h1
            margin-top: 0

        .ace_editor
          width: 700px
          height: 500px

#menu
    background-color menu-background
    .pure-menu-heading
        //padding-left: 40px
        //padding-right: 7px
        // width: 170px
        color white

    li
        a
            color menu-color
            &:hover
                background-color rgb(51, 51, 51)

        &.pure-menu-selected
            a
                -webkit-box-shadow inset 0 3px 8px rgba(0, 0, 0, 0.125)
                -moz-box-shadow inset 0 3px 8px rgba(0, 0, 0, 0.125)
                box-shadow inset 0 3px 8px rgba(0, 0, 0, 0.125)
                background-color: #111111
                color rgb(220, 220, 220)

footer
    //margin-top 5em
    margin-top 0px
    border-top 1px solid menu-background
    padding 1em
    color black
    text-align center
    font-size 80%

HTML

应用程序的 HTML,一个 Angular 模板 (angular.html) 和一个部分 (partials/home.html);你可能会注意到根 div 定义了一个纯响应式网格(类 pure-g-r),列是通过类 pure-u-1-5 定义的(左列)和pure-u-4-5(右栏):

Angular .html

<div class="content pure-g-r" data-ng-controller="MeteorCtrl">
    <header class="pure-u-1">
        <nav id="menu" class="pure-menu pure-menu-open pure-menu-fixed pure-menu-horizontal">
            <div class="pure-u-1-5">
                <div class="pure-menu-heading">Meteor-Ace</div>
            </div>

            <ul class="pure-u-4-5">
                <li data-ng-repeat="menuItem in menuItems">
                    <a href="{{menuItem.address}}">{{menuItem.name}}</a>
                </li>
            </ul>
        </nav>
    </header>

    <article id="content" class="pure-u-1">
        <div class="pure-g-r content-ribbon">
            <div class="pure-u-1">
                <div data-ng-view></div>
            </div>
        </div>
        <footer class="pure-u-1">
            Made with the excellent <a href="http://meteor.com/">Meteor</a> framework and
            <a href="http://meteor.com/">AngularJS</a>. © 2013 Arve Knudsen
        </footer>
    </article>
</div>

部分/home.html

<div class="pure-u-1-5">
    <div id="sidebar">Sidebar Content</div>
</div>

<div class="pure-u-4-5">
    <div id="editor-container">
        <h1><a href="http://ace.c9.io/">Ace</a> Editor Demo</h1>

        <!--<div data-ui-ace></div>-->
    </div>
</div>

最佳答案

事实证明,问题是我在列中嵌套了网格列(哎呀)。以下 HTML 已更正且未出现任何布局问题:

Angular .html

<div class="content pure-g-r" data-ng-controller="MeteorCtrl">
    <header>
        <nav id="menu" class="pure-menu pure-menu-open pure-menu-fixed pure-menu-horizontal">
            <div class="pure-u-1-5">
                <div class="pure-menu-heading">Meteor-Ace</div>
            </div>

            <ul class="pure-u-4-5">
                <li data-ng-repeat="menuItem in menuItems">
                    <a href="{{menuItem.address}}">{{menuItem.name}}</a>
                </li>
            </ul>
        </nav>
    </header>

    <article id="content">
        <div class="content-ribbon">
                <div data-ng-view></div>
        </div>
        <footer class="pure-u-1">
            Made with the excellent <a href="http://meteor.com/">Meteor</a> framework and
            <a href="http://meteor.com/">AngularJS</a>. © 2013 Arve Knudsen
        </footer>
    </article>
</div>

部分/home.html

<div class="pure-u-1-5">
    <div id="sidebar">Sidebar Content</div>
</div>

<div class="pure-u-4-5">
    <div id="editor-container">
        <h1><a href="http://ace.c9.io/">Ace</a> Editor Demo</h1>

        <div data-ui-ace></div>
    </div>
</div>

关于html - 为什么我的 2 列纯 CSS 布局不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18599813/

相关文章:

javascript - 使用 jQuery Animate 进行页面转换,同时修复封面图像

c# - ASP.NET:更改隐藏代码中的 CSS 链接 href?

html - CSS - 垂直而不是水平堆叠的元素

ios - 如何让 Cordova 通过插件自动嵌入自定义 iOS 框架?

javascript - div 内容更新后有功能工作

python - 从 BeautifulSoup html 解析器获取干净的文本文件

javascript - 单击它时如何弹出一个 float /粘性窗口?

css - 将 div 设置为底部且没有碰撞

javascript - Meteor:设置 Handlebars 变量 true/false

javascript - 如何构建 Meteor 应用程序并加载到 Meteor shell 中