利用flex布局实现仿微信群的多头像九宫格自适应布局

Posted by wantingtr on July 20, 2019

利用flex布局实现微信群的多头像自适应布

微信群聊的头像是多个成员的组合,例如下图。 avatar 可以看到根据单个小头像的大小可以分为三类,分别可以看做是整个大头像的98%,47%和31%。所以可以根据单个数组的长度,分别匹配不同的样式。而为了模拟后台返回的多头像接口,需要额外做一个判断,即最多只能显示9张头像。

<div id="app">
    <div class="avatar" v-for="(avatarItem,index) in avatarList">
        <image v-for="(item,index) in avatarItem" :src="item" :class="computedAvatar(avatarItem)" v-if="index < 9"></image>
    </div>
</div>
//计算头像布局
computedAvatar(avatarList) {
    if(avatarList.length > 4) {
        return "avatarItem--3"
    }else if(avatarList.length > 1) {
        return "avatarItem--2"
    }else {
        return "avatarItem--1"
    }
}

要做到多排的自适应布局,最简单的就是利用flex布局。最基本的是居中,即justify-content: center;align-content: center;。 除此之外,当单轴线排不下后,需换行。flex的换行方式有两种。分别是wrapwrap-reverse。这里用wrap-reverse

.avatar {
     width: 60px;
     height: 60px;
     overflow: hidden;
     display: flex;
     justify-content: center;
     align-items: center;
     align-content: center;
     flex-wrap: wrap-reverse;
     border: #000 1px solid;
     margin: 30px;
 }
 .avatarImg {
     width: 60px;
     height: 60px;
 }

 .avatarItem--1 {
     width: 98%;
     height: 98%;
 }

 .avatarItem--2 {
     width: 47%;
     height: 47%;
     margin: 1%;
 }

 .avatarItem--3 {
     width: 32%;
     height: 30%;
     margin: 1%;
 }