vue-mergeable-table 动态生成的可合并行列的表格
项目地址
可以根据数据动态生成可合并行列的表格。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-a63wCUjA-1594973943195)(/img/bVbJO6e)]](https://img-blog.csdnimg.cn/20200717161551381.png)
文档
数据选项
options: {
cols: 6, // 要生成的表格列数
rows: 7, // 要生成的表格行数 这个表是 7 * 6
data: [ // 表格数据,生成表格后将数据按顺序一一填充到表格
{ content: '测试1', id: 10, a: 100, b: 100 }, // content 字段为表格的内容
// 需要合并的数据需要填入一个 merge 对象
// row col 为起始行列,rowspan 和 colspan 为合并的行数,值默认为 1,为 1 时可以不填
// 这代表这个数据要放在 row 为 3,col 为 1 的单元格上,并且占 3 行 1列
{ content: '测试2', merge: { row: 3, col: 0, rowspan: 3 } },
{ content: '测试3' },
],
},
事件
组件可监听 click 事件,回调函数事件参数格式:
// 当前点击的数据 行数据 行索引 列索引,返回的行数据 行索引 列索引均以合并后的表格为准
handleClick(data, rowData, row, col) {
console.log(data)
console.log(rowData)
console.log(row)
console.log(col)
},
在线 DEMO
注意事项
假设你创建了一个 4*4 的表格,如下图所示。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-axL11m7K-1594973943196)(/img/bVbJO6g)]](https://img-blog.csdnimg.cn/20200717161613686.png)
现在每一行你都合并了 3 列,这时表格会发生崩溃现象。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aBIrMfEO-1594973943197)(/img/bVbJO6k)]](https://img-blog.csdnimg.cn/20200717161629102.png)
这是表格自身的问题,和组件无关。要解决此问题,只需再加一行没有合并的表格即可。
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-C3XJtFGr-1594973943199)(/img/bVbJO6l)]](https://img-blog.csdnimg.cn/20200717161641272.png)
使用
在单文件组件中引用
npm i vue-mergeable-table
import VueMergeableTable from 'vue-mergeable-table'
Vue.use(VueMergeableTable)
<template>
<div id="app">
<VueMergeableTable :options="options" @click="handleClick" />
// 或者 <vue-mergeable-table :options="options"/>
</div>
</template>
在HTML文件中直接引用
使用的是dist目录中的 vue-mergeable-table.js
<div id="app">
<vue-mergeable-table :options="options" @click="handleClick"></vue-mergeable-table>
</div>

浙公网安备 33010602011771号