组件布局
布局是开发 Web 页面最常接触的一个方面,也是页面最直观的一种展现方式。然而在开发前端页面的时候很多工程师会为布局感到头疼,不仅是因为不同浏览器厂商兼容程度的不同,而且还有诸多如适配不同分辨率屏幕所带来的问题、实现起来比较复杂的问题等种种情况。不过在使用了 MIP 之后我们不需要再为这些问题烦恼,MIP 提供了一整套完备的组件布局系统,支持不同布局类型和方式,开发者需要做的仅仅是为组件指定布局属性即可。
MIP 组件支持的各种布局,可以让图片屏幕自适应、定高等。用于预先给组件确定占位,防止组件内容加载后撑开页面,造成页面内容抖动,浏览器重排重绘,简称为 layout 。
使用方式
在使用 MIP 布局时,开发者无需关心任何场景和兼容性问题,仅仅只需要在组件加入 layout 属性即可,如下面所示。
1<mip-img layout="responsive" src="https://image.com/img.jpeg"></mip-img>
组件布局方式
MIP 根据主流布局方式考虑,封装了 7 大布局法则,具体如下面表格所示:
类 别 | 强制 width | 强制 height | 详细说明 |
---|---|---|---|
responsive | 是 | 是 | 能够根据 width、height 的值,算出元素对应的比例,在不同屏幕宽度上做自适应,非常适合图片、视频等需要大小自适应的组件 |
fixed-height | 否 | 是 | 元素的高度固定,width 缺省或者取值为 auto,比较适合 <mip-carousel> |
fill | 否 | 否 | 元素的大小根据父节点的大小自动撑开 |
container | 否 | 否 | 元素的大小由它们的子节点大小决定,与 HTML 的 div 标签类似 |
nodisplay | 否 | 否 | 元素不展现,即 display:none; 的时候,这种元素可应用于它自身展现依赖用户的点击等行为的触发 |
fixed | 是 | 是 | 元素根据 width和 height 固定高宽,不随 media 变化 |
flex-item | 否 | 否 | 元素通过 flex 进行布局,需设置父元素为 display:flex; |
layout 详解
1. responsive
- 布局介绍:使用
layout="responsive"
的组件能够根据width
、height
的值,算出元素对应的比例,在不同屏幕宽度上做自适应。 - 适用场景:图片、视频、图片轮播等需要按比例自动缩放的元素。
- 代码示例:
123456<mip-img
layout="responsive"
width="350"
height="263"
src="/doc/image/layout/img.jpg">
</mip-img>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/responsive.mp4"
poster="/doc/image/layout/responsive.png">
</mip-video>
2. fixed-height
- 布局介绍:使用
layout="fixed-height"
的组件高度固定,不随屏幕大小变化。width
缺省或者取值为auto
。 - 适用场景:高度固定的广告位、音频播放组件、mip-fixed悬浮组件。
- 代码示例:
12345<mip-img
layout="fixed-height"
height="263"
src="/doc/image/layout/img.jpg">
</mip-img>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/fixed-height.mp4"
poster="/doc/image/layout/fixed-height.png">
</mip-video>
3. fixed
- 布局介绍:使用
layout="fixed"
的组件宽高固定,根据width
和height
取值(px)固定宽高,元素尺寸不随屏幕大小变化。 - 适用场景:头像图片、表情GIF、后退按钮 等有固定大小的元素。
- 代码示例:
123456<mip-img
layout="fixed"
width="350"
height="263"
src="/doc/image/layout/img.jpg">
</mip-img>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/fixed.mp4"
poster="/doc/image/layout/fixed.png">
</mip-video>
4. flex-item
- 布局介绍:使用
layout="flex-item"
的组件通过flex
进行布局,需设置父元素为display: flex
,元素的大小根据父节点的大小自动撑开。 - 适用场景:多图横向排列,左右内容对比布局。
- 代码示例:
1234567891011<style>
#container {
display: flex;
height: 200px;
}
</style>
<section id="container">
<mip-img layout="flex-item" src="/doc/image/layout/img.jpg"></mip-img>
<mip-img layout="flex-item" src="/doc/image/layout/img.jpg"></mip-img>
<mip-img layout="flex-item" src="/doc/image/layout/img.jpg"></mip-img>
</section>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/flex-item.mp4"
poster="/doc/image/layout/flex-item.png">
</mip-video>
5. fill
- 布局介绍:使用
layout="fill"
的元素的大小根据父节点的大小自动撑开。 - 适用场景:铺满父元素的背景图片。
- 代码示例:
12345678910111213<style>
.container {
position: relative;
height: 300px;
width: 80%;
}
</style>
<section class="container">
<mip-img
layout="fill"
src="img.jpg">
</mip-img>
</section>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/fill.mp4"
poster="/doc/image/layout/fill.png">
</mip-video>
6. container
1234<mip-history history="go, -1" layout="container">
我说你是人间的四月天;笑声点亮了四面风;轻灵在春的光艳中交舞着变。你是四月早天里的云烟,黄昏吹着风的软,星子在无意中闪,细雨点洒在花前。那轻,那娉婷,你是,鲜妍百花的冠冕你戴着,你是天真,庄严,你是夜夜的月圆。
</mip-history>
<script src="https://c.mipcdn.com/static/v1/mip-history/mip-history.js"></script>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/container.mp4"
poster="/doc/image/layout/container.png">
</mip-video>
7. nodisplay
- 布局介绍:使用
layout="nodisplay"
的元素不展现,即display: none
。隐藏元素可由用户点击触发显示,也可以应用于统计组件。 - 适用场景:不需要显示在页面上的mip-pix统计、mip-analytics统计、百度统计组件,由用户点击触发的mip-lightbox弹框组件。
- 代码示例:
12345678<button on="tap:L1.toggle" id="btn-open" class="lightbox-btn">
打开弹层
</button>
<mip-lightbox layout="nodisplay" class="mip-hidden" id="L1">
<div class="lightbox">
<span on="tap:L1.toggle" class="lightbox-btn">关闭弹层</span>
</div>
</mip-lightbox>
- 使用效果:
1234<mip-video controls loop layout="fixed-height" height="350" class="white-bg"
src="/doc/image/layout/nodisplay.mp4"
poster="/doc/image/layout/nodisplay.png">
</mip-video>
layout 属性缺省规则
width | height | 其他属性 | 默认布局 |
---|---|---|---|
有 | 有 | 无 | fixed |
有 | 有 | 存在 sizes 参数 | responsive |
无或取值为 auto | 有 | 无 | fixed-height |
无 | 无 | 无 | container |
layout 默认值
所有 MIP 元素都会有 layout
。移动端的设计大部分是块状的,默认的 layout
是 container
。如果有其它的样式需求,如 inline
、inline-block
。可通过 CSS 样式覆盖的方式修改元素 display
属性。