最近在用vue.js
框架开发小程序,对于「前端知识」几乎为0的我,用html+css
调整布局,真是让我分分钟有想拍桌子的冲动啊,但是工作毕竟是工作呀,拍完桌子还是要静下心来调布局对不对。
在经过几周各种挫折的开发,今天将一些项目中运用的常用布局做个整理 。
案例1: 「头像加V」
data:image/s3,"s3://crabby-images/fe69c/fe69ce5f05aaff70f2f4bcf65ff7d19f2db8f812" alt=""
要点:
-
左右布局:
很自然想到使用盒子布局, 左右布局即:flex-direction:row
-
底边对齐
在盒子布局里,有一个属性 align-self ,
align-self
:定义flex
子项单独在「侧轴(纵轴)」方向上的对齐方式。所以 align-self:flex-end
即可。
data:image/s3,"s3://crabby-images/a91b2/a91b22e4da41115c09d136f6c3bb1e75062daa08" alt=""
-
右边对齐
如果不设置加v图片的margin
,那么就会是左右结构,所以设置margin-left : 图片的宽度
,就可以保证右对齐。
- 图片圆角
图片的四个角的圆角都可以单独设置,比如设置成下图的圆角:不同的圆角.png 可以写成
border-radius:15rpx 30rpx 60rpx 120rpx;
中间用空格分开,顺序为(上,右,下,左)
「头像加V」的源码
<template>
<div class="avatar-container">
<img class="avatar" :src="url"></img>
<img class="vip-icon" src="/static/drawable/icon_vip.png"></img>
</div>
</template>
<style>
.avatar-container {
display:flex;
flex-direction:row;
}
.vip-icon {
width:24rpx;
height:24rpx;
align-self:flex-end;
margin-left:-24rpx;
}
.avatar {
width:80rpx;
height:80rpx;
border-radius:40rpx;
}
</style>
案例2: 「回放」
data:image/s3,"s3://crabby-images/499de/499deb02b8a58350d926ab038a87482298718a50" alt=""
要点:
- 当
margin
指定一个值,那么会作用到四个方向。 - 当
margin
指定两个值,第一个值会应用到top
和bottom
,第二个值应用到left
和right
; - 当
margin
指定三个值,第一个值是top
,第二个值是left
和right
, 第三个值是bottom
; - 当
margin
指定四个值,则会按照top
,right
,bottom
,left
顺序依次应用到各个方向。(逆时针)
- 「图2」 在「图1」上方,且居中显示。
这里要涉及到position, 对应的四个属性top
,left
,right
,bottom
来决定最终的位置。
-
static
:默认值,没有定位,top
,left
,right
,bottom
不起作用 -
relative
:top
,left
,right
,bottom
的值是相对于自身原有的位置做偏移。 -
absolute
:top
,left
,right
,bottom
的值,对于static
定位以外的第一个父元素进行定位. -
fixed
: 生成绝对定位的元素,相对于浏览器窗口进行定位,top
,left
,right
,bottom
来决定最终位置。
所以综合上述margin
和 position
可推出对应的属性进行如下设置时便可以居中显示。
position: absolute;
margin: auto;
top: 0;
left: 0;
bottom: 0;
right: 0;
最后放出整个效果的源码:
「回放」源码 :
<template>
<div class="vod-container">
<img class="vod-cover" :src="url"></img>
<img class="vod-play" src="/static/drawable/elvideo_icon_video_play.png"></img>
</div>
</template>
<style>
.vod-container {
position: relative;
height: 340rpx;
margin-top:200rpx;
margin-left: 12rpx;
margin-right: 12rpx;
}
.vod-cover {
position: absolute;
width: 100%;
height: 340rpx;
border-radius: 8rpx;
}
.vod-play {
position: absolute;
width: 100rpx;
height: 100rpx;
margin: auto;
top: 0;
left: 0;
bottom: 0;
right: 0;
}
</style>
网友评论