组件布局

布局是开发 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" 的组件能够根据 widthheight 的值,算出元素对应的比例,在不同屏幕宽度上做自适应。
  • 适用场景:图片视频图片轮播等需要按比例自动缩放的元素。
  • 代码示例:
1
2
3
4
5
6
<mip-img layout="responsive" width="350" height="263" src="/doc/image/layout/img.jpg"> </mip-img>
  • 使用效果:
1
2
3
4
<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

1
2
3
4
5
<mip-img layout="fixed-height" height="263" src="/doc/image/layout/img.jpg"> </mip-img>
  • 使用效果:
1
2
3
4
<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" 的组件宽高固定,根据 widthheight 取值(px)固定宽高,元素尺寸不随屏幕大小变化。
  • 适用场景:头像图片表情GIF后退按钮 等有固定大小的元素。
  • 代码示例:
1
2
3
4
5
6
<mip-img layout="fixed" width="350" height="263" src="/doc/image/layout/img.jpg"> </mip-img>
  • 使用效果:
1
2
3
4
<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 ,元素的大小根据父节点的大小自动撑开。
  • 适用场景:多图横向排列,左右内容对比布局。
  • 代码示例:
1
2
3
4
5
6
7
8
9
10
11
<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>
  • 使用效果:
1
2
3
4
<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" 的元素的大小根据父节点的大小自动撑开。
  • 适用场景:铺满父元素的背景图片。
  • 代码示例:
1
2
3
4
5
6
7
8
9
10
11
12
13
<style> .container { position: relative; height: 300px; width: 80%; } </style> <section class="container"> <mip-img layout="fill" src="img.jpg"> </mip-img> </section>
  • 使用效果:
1
2
3
4
<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

  • 布局介绍:使用 layout="container" 的元素的大小根据子节点的大小自动撑开,相当于 display: block
  • 适用场景:内容高度不固定的表单无限滚动组件。
  • 代码示例:
1
2
3
4
<mip-history history="go, -1" layout="container"> 我说你是人间的四月天;笑声点亮了四面风;轻灵在春的光艳中交舞着变。你是四月早天里的云烟,黄昏吹着风的软,星子在无意中闪,细雨点洒在花前。那轻,那娉婷,你是,鲜妍百花的冠冕你戴着,你是天真,庄严,你是夜夜的月圆。 </mip-history> <script src="https://c.mipcdn.com/static/v1/mip-history/mip-history.js"></script>
  • 使用效果:
1
2
3
4
<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弹框组件。
  • 代码示例:
1
2
3
4
5
6
7
8
<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>
  • 使用效果:
1
2
3
4
<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 属性缺省规则

widthheight其他属性默认布局
fixed
存在 sizes 参数responsive
无或取值为 autofixed-height
container

layout 默认值

所有 MIP 元素都会有 layout 。移动端的设计大部分是块状的,默认的 layoutcontainer 。如果有其它的样式需求,如 inlineinline-block。可通过 CSS 样式覆盖的方式修改元素 display 属性。