首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >HTML对齐最后一列

HTML对齐最后一列
EN

Stack Overflow用户
提问于 2021-12-07 17:42:01
回答 1查看 317关注 0票数 1

我有个问题。对于我当前的项目,我有一个包含列表的页面。该列表包含posts,它显示在css grid中。网格的最后2列必须是右边的text-aligned,但这是行不通的。下面是代码片段:

代码语言:javascript
复制
mat-form-field {
    margin: 0px 10px;
}

/**
 * Add basic flex styling so that the cells evenly space themselves in the row.
 */
mat-list {
    display: flex;
    flex-direction: column;
    margin-right: 10px;
}

.profile-picture-container {
    height: 40px;
    width: 40px;
    position: relative;
    text-align: center;
    color: white;
}

.profile-picture-container > img {
    height: 100%;
    width: 100%;
    border-radius: 50%;
}

.fa-play {
    color: white;
}

#btnToggleAudio {
    background-color: transparent;
    border: none;
    display: none;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10000;
}

mat-list-item {
    flex: 1;
}

.header {
    font-weight: bold;
}

h3 {
    padding-bottom: 5px;
}

.item-grid {
    display: grid;
    grid-template-columns: 60px 40% 20% 20% 20%;
    align-items: center;
}

.item-grid > div {
    display: flex;
    align-items: center;
}

.right {
    text-align: right;
}

mat-list-item:hover {
    background-color: #c4c4c4;
}

mat-list-item:hover #profile-picture {
    filter: brightness(70%);
}

mat-list-item:hover #btnToggleAudio {
    display: block;
}

.action-button{
    height: 30px!important;
    width: 50px!important;
    min-width: unset!important;
}

.mat-icon-align {
    vertical-align: middle;
}

@media (max-width: 900px) {
    .item-grid {
        display: grid;
        grid-template-columns: 50% 25% 25%;
    }

    .desktop-only {
        display: none;
    }
}
代码语言:javascript
复制
<mat-list>
    <h3 matHeader>Reported posts</h3>
    <mat-list-item>
        <div matLine>
            <div class="item-grid" matline>
                <div class="profile-picture-container" style="grid-row: 1 / 3">
                    <img id="profile-picture" src="/assets/images/post_city.jpg">
                    <button id="btnToggleAudio" (click)="onDismissClick(1)">
                        <i class="fas fa-play"></i>
                    </button>
                </div>
                <div class="header">Title</div>
                <div class="header desktop-only">Username</div>
                <div class="header right">Reports</div>
                <div class="header right" style="background-color: blue">Actions</div>
                <div>Test post</div>
                <div class="desktop-only">Dummy-2000</div>
                <div class="right">3</div>
                <div class="right" style="background-color: blue">
                    <button mat-button class="action-button right">
                        <mat-icon class="mat-icon-align">check_circle</mat-icon>
                    </button>
                    <button mat-button class="action-button right">
                        <mat-icon class="mat-icon-align">delete</mat-icon>
                    </button>
                </div>
            </div>
        </div>
    </mat-list-item>
    <mat-divider></mat-divider>
</mat-list>

如您所见,报表和操作不对齐,而它们都包含类right。此外,动作按钮中的图标不是完全居中的,如下所示:

您可以看到上面删除按钮的背景色发生了一点变化。图标位于右下角。我试图将它们与类:.mat-icon-align对齐,但这并不是完全以中心为中心的。

我怎样才能让这两件事起作用?

更新

使用justify-content: flex-end;的结果如下:

在网格的末尾,最后一列在屏幕之外?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-07 17:59:06

你需要改变

代码语言:javascript
复制
.right {
  text-align: right;
}

代码语言:javascript
复制
.right {
    justify-content: flex-end;
}

当使用flex-boxgrid时,浏览器改变了内部内容空间的分布方式。您的问题是,带有类div.right不是单元格的全部宽度,类上的justify-content: flex-end;会像您所要求的那样将内容推到最右边。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70264657

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档