Skip to content

Zori 中的 Grid

需求

实现一个 Vue 中能使用的栅栏网格,总计每行为 24 份,用户可选择每一列所占份数,左边间隔(可以没有),以及可显示输入每一份之间的间隔(可以没有)。

实现

组件

用两个组件 col.vue 以及 row.col 表示列以及行

col.vue

用户再输入标签时带上数据 span 以及 offset 代表份数及左边间隔,使用 props 传入,间隔更具传入的数据用 scss 进行更改样式

scss
$class-prefix: span-;
@for $n from 1 through 24{
    &.#{$class-prefix}#{$n}{
        width: ($n/24)*100%;
    }
}

本来样式最开始的时候我是写在 template 上的,但是一旦数据增加上去的话可读性就送到了影响,就放到 script 中,由于 spanoffset 是在组件中是会改变的于是使用计算属性,同时我使用了 ES6 结构赋值。

row.vue

行组件代码是比列组件是要少上不少的但是有一个难点,所以理解上是比列组件要复杂点的。

之前有一个需求是可以输入每一块的间隔,由于这个间隔对于每一个行组件中的列组件是一样的,所以我们没必要写在列组件上而是写在行组件上就好了,就好像事件代理一样。但是我们应该如何通过行组件告知列组件他们的间隔(gutter)呢?

这就要用到生命周期 mountedmounted 是在 created 之后的,产生后挂载。所以我们可以在他们挂载后将 gutter 传给他们的子组件

JavaScript
mounted(){
    this.$children.foreach((vm)=>{
        vm.gutter = this.gutter
    })
}