MDL mdl-layout-spacer强制内容到下一行

时间:2017-02-16 09:58:54

标签: javascript html css material-design-lite

这是一个非常基本的Material Design Lite问题,但这让我很疯狂。在MDL examples website的以下示例中,div与类mdl-layout-spacer很好地将后面的元素放在包含div的右侧。请注意,日历图标位于右侧:

enter image description here

<!-- Event card -->
<style>
    .demo-card-event.mdl-card {
        width: 256px;
        height: 256px;
        background: #3E4EB8;
    }

    .demo-card-event>.mdl-card__actions {
        border-color: rgba(255, 255, 255, 0.2);
    }

    .demo-card-event>.mdl-card__title {
        align-items: flex-start;
    }

    .demo-card-event>.mdl-card__title>h4 {
        margin-top: 0;
    }

    .demo-card-event>.mdl-card__actions {
        display: flex;
        box-sizing: border-box;
        align-items: center;
    }

    .demo-card-event>.mdl-card__actions>.material-icons {
        padding-right: 10px;
    }

    .demo-card-event>.mdl-card__title,
    .demo-card-event>.mdl-card__actions,
    .demo-card-event>.mdl-card__actions>.mdl-button {
        color: #fff;
    }
</style>
<div class="demo-card-event mdl-card mdl-shadow--2dp">
    <div class="mdl-card__title mdl-card--expand">
        <h4> Featured event:<br> May 24, 2016<br> 7-11pm </h4>
    </div>
    <div class="mdl-card__actions mdl-card--border"> <a class="mdl-button mdl-button--colored mdl-js-button mdl-js-ripple-effect">
      Add to Calendar
    </a>
        <div class="mdl-layout-spacer"></div> <i class="material-icons">event</i> </div>
</div>

现在问题。我在我的网站中的几个不同情况下尝试过mdl-layout-spacer技术,但它似乎只适用于网站标题中的图标。请参阅此图片右侧的徽章图标:

enter image description here

我希望能够在卡中使用这种技术,但它似乎不起作用。我使用以下html创建了JSFiddle example。使用mdl-layout-spacer,我希望“today”这个词位于包含div的右侧,但正如您所看到的那样,它会下降到下一行。

我错过了什么吗?我是否应该像预期的那样使用垫片?或者我是否需要放弃这个目标?

<body>
    <div class="demo-layout mdl-layout mdl-js-layout mdl-layout--fixed-drawer mdl-layout--fixed-header">
        <main class="mdl-layout__content">
            <div class="mdl-grid">
                <div class="full-width-card hover-card mdl-cell mdl-cell--12-col-desktop mdl-cell--12-col-tablet mdl-card mdl-shadow--2dp" style="min-height:100px;">
                    <div class="mdl-card__supporting_text">
                        <a class="no-decoration" href="#"> <span style="display:inline-block;">
                    username
                  </span> <span style="display:inline-block;">
                    <i class="material-icons">acct_icon</i>
                  </span> </a>
                        <!-- spacer -->
                        <div class="mdl-layout-spacer"></div>
                        <!-- --><span style="display:inline-block;">today</span> </div>
                </div>
            </div>
        </main>
    </div>
</body>

enter image description here

1 个答案:

答案 0 :(得分:1)

不,那不是真的。 mdl-layout-spacer类并非特定于图标。 检查我创建的codepen example。我使用的是文字而不是图标,而且工作正常。

在卡片示例中,您使用了样式:

.demo-card-event>.mdl-card__actions {
    display: flex;
    box-sizing: border-box;
    align-items: center;
}

这是将元素推向右侧的代码。查看此JsFiddle我使用相同的CSS来修复您的示例。

已修改:您的示例无效,因为您的元素没有display: flex css。所以只需将此css添加到父类:

.mdl-card__supporting_text {
    display: flex;
}