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

在网格的末尾,最后一列在屏幕之外?
发布于 2021-12-07 17:59:06
你需要改变
.right {
text-align: right;
}至
.right {
justify-content: flex-end;
}当使用flex-box和grid时,浏览器改变了内部内容空间的分布方式。您的问题是,带有类div的.right不是单元格的全部宽度,类上的justify-content: flex-end;会像您所要求的那样将内容推到最右边。
https://stackoverflow.com/questions/70264657
复制相似问题