美文网首页
UI组件库-封装列布局组件(栅格)

UI组件库-封装列布局组件(栅格)

作者: 前端巴士 | 来源:发表于2020-07-22 17:44 被阅读0次

    基本上所有的UI组件库都有自己的布局组件,我们也要有,看了下Bulma,其中的布局组件叫columns。翻了下,实现的东西足够用了,下面就开始动手吧

    几个要注意点

    1. Bulma的columns完全基于CSS3的flex布局
    2. Bulma的栅格分12列
    3. Bulma实现的布局方式有多种,我们只选择了其中比较常用的

    一,各列宽度都相等的情况

    UI组件库-封装列布局组件(栅格)

    如上图,Bulma处理的相当简便,我们的组件目录安排如下:

    - components  - columns    - Row.vue    - Columns.vue
    

    Row.vue 的主要内容如下:

    <div class="columns"></div>
    

    Columns.vue 的主要内容如下:

    <div class="column">    First column  </div>
    

    用法:

    <Row>      <Column>        <div class="red">111</div> <!-- .red 是自定义样式 -->      </Column>      <Column>        <div class="red">222</div> <!-- .red 是自定义样式 -->      </Column></Row>
    

    对于要平均分配父元素宽度的子元素来说,这个很方便,有几个子元素,就放几个<Column>就可以了

    二,列宽度不相等的情况

    这个情况很常见,Bulma有不同的实现方式,比如使用样式 is-two-thirds 表示此列宽度占总宽度的三分之二。之前的习惯的原因,感觉不是特别喜欢这样的用法,还好Bulma还支持栅格化的做法,不过栅格是和Bootstrap类似的12列布局而不是Element的24列布局,这点对用习惯Element的童鞋还是要留意一下。

    UI组件库-封装列布局组件(栅格)

    如上图,样式名是 is-数字 的形式,正好可以和Element一样,把数字给咱们的组件,咱们就给它分配相应的宽度,感觉没啥问题了。

    三,列间距的问题

    经常会有列之间的距离要自定义的情况,咱们也要支持,这一块Bulma处理的也很好

    UI组件库-封装列布局组件(栅格)

    如上图,只需要在 .columns 后面加一个 is-数字 就可以了!

    说明一下:数字的取值范围【0, 8】,另外还需特别注意的是,除了这个 is-数字 之外还要加一个 is-variable 样式才可以正常工作,切记!

    四,被忘记的列偏移问题

    这块Bulma是支持的,不过放到了一个不是特别明显的位置,我们平时也比较常用,就加上它

    UI组件库-封装列布局组件(栅格)

    再如上图,Bulma的实现方式还是有多种,咱们还是选 is-数字 这样的形式的,其实关键点就是把一个样式名加到 .column 的后面!

    行了,上面就是组件要搞定的问题,让我们很轻松的就可以排版布局页面,如果你都清楚要求的,下面就开始吧

    直接上代码:

    // Coumn<template>  <div class="column" :class="[span?'is-'+span:'', offset?'is-offset-'+offset:'']">    <slot></slot>  </div></template><script>export default {  props: {    span: {      type: Number,      default: 0    },    offset: {      type: Number,      default: 0    }  }};</script>// Row<template>  <div class="columns" :class="[gap?'is-variable is-'+gap:'']">    <slot></slot>  </div></template><script>export default {  props: {    gap: {      type: Number,      default: 3    }  }};</script>
    

    然后就可以很省事的使用了:

    <Row>      <Column>        <div class="red"></div>      </Column>    </Row>    <hr />    <Row :gap="3">      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>    </Row>    <hr />    <Row :gap="3">      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>    </Row>    <hr />    <Row>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>      <Column>        <div class="red"></div>      </Column>    </Row>    <hr />    <Row>      <Column :span="3">        <div class="red"></div>      </Column>      <Column :span="9">        <div class="red"></div>      </Column>    </Row>    <hr />    <Row>      <Column :span="3">        <div class="red"></div>      </Column>      <Column :span="5" :offset="1">        <div class="red"></div>      </Column>      <Column :span="3">        <div class="red"></div>      </Column>    </Row>
    

    截张图上来:

    UI组件库-封装列布局组件(栅格)

    多谢留言关注!

    相关文章

      网友评论

          本文标题:UI组件库-封装列布局组件(栅格)

          本文链接:https://www.haomeiwen.com/subject/vlutlktx.html