前言vue-split-table应用的效果图vue-split-table开源地址,欢迎star,现在已经开源和同步到npm上轻松搞定表格拆分或者合并,编辑,再也不怕被产品怼啦1.核心源码分析<td>里面嵌套<table>实现表格拆分;原生实现复选框的单选和全选功能;props属性像父组件暴露属性值;$emit自定义事件方法向父组件传值;作用域插槽<template slot-scope>由父向子传入html标签;嵌套<input>实现表格编辑,v-for不允许<input>里面使用v-model改变item值问题解决;webpack打包配置vue-split-table开源地址,欢迎star和pr2.暴露的Attributes参数说明类型是否必传DefaultheadData表头内容Array必传-bodyData表体内容Array必传-checkFlag是否有复选列Boolean可选TruetableEditFlag表格是否可编辑Boolean可选TrueoperFlag是否有操作列Boolean可选True3.暴露的Eventsname说明参数multipleData当选项发生变化触发multipleDataeditData表格编辑文本框失焦触发editData4.slot事件名说明operate配置操作列后就可通过设置slot来配置操作的内容5.撸起示例代码基于vue工程<template> <split-table :headData=“headData” :bodyData=“bodyData” @multipleData=“multipleData” @editData=“editData”> <template slot=“operate” slot-scope=“props”> <span @click=“splitEdit(props.rowData)">修改</span> <span @click=“splitAdd(props.rowData)">新增</span> <span @click=“splitDel(props.rowData)">删除</span> </template> </split-table></template><script> import SplitTable from ‘vue-split-table’; export default { components: { SplitTable }, data () { return { headData: [“城市”, “美食”, “好玩的地方”], bodyData: [ { city: “北京”, food: “北京烤鸭”, fun: [“故宫”, “颐和园”, “长城”] }, { city: “深圳”,food: [“肠粉”, “牛肉火锅”],fun: [“西冲”, “华侨城”, “世界之窗”] }, { city: [“重庆”, “成都”, “武汉”], food: [“重庆老火锅”,“重庆烤鱼”,“重庆小面”,“成都小吃”,“武汉热干面”], fun: [“洪崖洞”, “峨眉山”, “黄鹤楼”] } ], } }, methods: { splitEdit(rowData) { console.log(“rowData值为”, rowData); }, editData(data) { console.log(“编辑所在行的值为”, data); } splitAdd(data) { console.log(“新增所在行的值为”, data); }, splitDel(data) { console.log(“删除所在行的值为”, data); }, multipleData(data) { console.log(“复选框选择的值为”, data); } } }</script>参考文章:时钟组件