宫格 Grid

基础宫格布局,常见应用场景为微信支付页面。

宫格共包含 2 个组件: gridgrid-item ,这两个组件必须配合使用。

基本使用

grid 包裹在所有 grid-item 最外层, grid 下的所有 grid-item 属于同一个 grid;

grid-item 用于设置每一个宫格元素的内容及事件。

示例代码

默认

  1. <l-grid>
  2. <l-grid-item key="one" slot="one">
  3. <view class="num">3</view>
  4. <view class="text">助力</view>
  5. </l-grid-item>
  6. <l-grid-item key="two" slot="two">
  7. <view class="num">134</view>
  8. <view class="text">点赞</view>
  9. </l-grid-item>
  10. <l-grid-item key="three" slot="three">
  11. <view class="num">1648</view>
  12. <view class="text">评论</view>
  13. </l-grid-item>
  14. </l-grid>

注意事项

  • 必须在 grid-item 上设置 slotkey,且两者值必须相等。因为在微信小程序中slot属性不能被获取到,所以必须设置一个和slot值一样的 key,以便于将子组件的元素插入到合适的位置。

设置边框

默认边框不显示,grid 提供了三个属性设置边框显示,这三个属性接收的值是布尔值,分别如下:

  • show-border="true" 显示所有的边框;
  • show-row-border="true" 显示横向边框;
  • show-col-border="true" 显示纵向边框;

示例代码

设置边框

  1. <l-grid l-class-grid="grid-item" show-border="{{true}}">
  2. <l-grid-item
  3. wx:for="{{grids1}}" wx:key="{{index}}" key="{{index}}" slot="{{index}}">
  4. <l-icon name="{{item.image}}" />
  5. <view class="text">{{item.text}}</view>
  6. </l-grid-item>
  7. </l-grid>

设置每行数目

默认每行3个宫格,可以使用 row-num 自定义每行显示的宫格数目。

示例代码

设置每行数目

<l-grid l-class-grid="grid-item" row-num="4" show-col-border="{{true}}">
    <l-grid-item 
      wx:for="{{grids2}}" wx:key="{{index}}" key="{{index}}" slot="{{index}}">
        <l-icon name="{{item.image}}" />
        <view class="text">{{item.text}}</view>
    </l-grid-item>
</l-grid>

宫格属性 (Grid Attributes)

参数说明类型可选值默认值
l-class外部样式类,设置整体宫格样式String--
rowNum每行显示的宫格数目String-3
show-border控制是否显示所有的边框Booleanfalse
show-row-border控制是否显示横向边框Booleanfalse
show-col-border控制是否显示纵向边框Booleanfalse-

宫格事件 (Grid Events)

事件名称说明返回值备注
bind:lintap点击grid整体时的事件e.detail 中,返回当前点击 grid-item 的索引-

宫格元素属性 (GridItem Attributes)

参数说明类型可选值默认值
keygrid-item显示所需,必填String--
slotkey一致,必填String--
l-grid-item外部样式类,覆盖每个宫格元素的样式String--

宫格元素事件 (GridItem Events)

事件名称说明返回值备注
bind:lintap监听点击grid-item的事件e.currentTarget中,当前点击grid-item-