|
@ -126,52 +126,72 @@ export default { |
|
|
return spans |
|
|
return spans |
|
|
}, |
|
|
}, |
|
|
/** |
|
|
/** |
|
|
* 添加行 |
|
|
* 添加行 |
|
|
* @param tableData$refs 表 |
|
|
* @param tableData$refs 表 |
|
|
* @param row 默认行数据,如果C1为true,那么则将C1的数值转换为索引值;如果不给则默认为{} |
|
|
* @param row 默认行数据,如果C1为true,那么则将C1的数值转换为索引值;如果不给则默认为{} |
|
|
*/ |
|
|
* @param indexColumn 序号的字段 |
|
|
addRow(tableData$refs, row) { |
|
|
*/ |
|
|
|
|
|
addRow(tableData$refs, row, indexColumn) { |
|
|
if (!row) { // 如果没有给出每行默认值时
|
|
|
if (!row) { // 如果没有给出每行默认值时
|
|
|
row = {} |
|
|
row = {} |
|
|
} |
|
|
} |
|
|
row.index = tableData$refs.data.length |
|
|
|
|
|
if (row.C1) { |
|
|
// 序号
|
|
|
tableData$refs.columns.some((v) => { |
|
|
const index = tableData$refs.data.length + 1 |
|
|
if (v.property && v.type === 'index') { |
|
|
|
|
|
row[v.property] = tableData$refs.data.length + 1 |
|
|
// 如果存在index列,则将index列按排序生成,从1开始数
|
|
|
return true |
|
|
tableData$refs.columns.some((v) => { |
|
|
} |
|
|
if (v.property && v.type === 'index') { |
|
|
}) |
|
|
row.index = index |
|
|
|
|
|
return true |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
|
|
|
// 如果存在序号字段,则将序号按排序生成,从1开始数
|
|
|
|
|
|
if (indexColumn) { |
|
|
|
|
|
row[indexColumn] = index |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
tableData$refs.data.push(row) |
|
|
tableData$refs.data.push(row) |
|
|
setTimeout(() => { |
|
|
setTimeout(() => { |
|
|
tableData$refs.setCurrentRow(row) |
|
|
tableData$refs.setCurrentRow(row) |
|
|
}, 10) // 用于延时渲染后选中这行
|
|
|
}, 10) // 用于延时渲染后选中这行
|
|
|
}, |
|
|
}, |
|
|
/** |
|
|
/** |
|
|
* 删除行(需要保证每一行都有一个index属性) |
|
|
* 删除行 |
|
|
* 建议使用方法:index列要有这个属性 :index="indexMethod" |
|
|
* @param tableData$refs 表 |
|
|
* 建议方法内容: |
|
|
* @param indexColumn 序号的字段 |
|
|
* indexMethod(index) { |
|
|
*/ |
|
|
this.tableData[index].index = index |
|
|
delRow(tableData$refs, indexColumn) { |
|
|
return (index + 1) |
|
|
|
|
|
} |
|
|
|
|
|
* @param tableData$refs 表 |
|
|
|
|
|
*/ |
|
|
|
|
|
delRow(tableData$refs) { |
|
|
|
|
|
if (tableData$refs.selection.length === 0) { |
|
|
if (tableData$refs.selection.length === 0) { |
|
|
Vue.prototype.$message({ |
|
|
Vue.prototype.$message({ |
|
|
message: '请选中需要删除的数据!', |
|
|
message: '请选中需要删除的数据!', |
|
|
type: 'error' |
|
|
type: 'error' |
|
|
}) |
|
|
}) |
|
|
} else { |
|
|
} else { |
|
|
|
|
|
// 删除选中的行
|
|
|
for (let i = 0; i < tableData$refs.selection.length; i++) { |
|
|
for (let i = 0; i < tableData$refs.selection.length; i++) { |
|
|
const index = tableData$refs.data.indexOf(tableData$refs.selection[i]) |
|
|
const index = tableData$refs.data.indexOf(tableData$refs.selection[i]) |
|
|
tableData$refs.data.splice(index, 1) |
|
|
tableData$refs.data.splice(index, 1) |
|
|
} |
|
|
} |
|
|
for (let i = 0; i < tableData$refs.data.length; i++) { |
|
|
|
|
|
tableData$refs.data[i].index = i + 1 |
|
|
// 如果存在index列,则将index列按排序生成,从1开始数
|
|
|
|
|
|
tableData$refs.columns.some((v) => { |
|
|
|
|
|
if (v.property && v.type === 'index') { |
|
|
|
|
|
for (let i = 0; i < tableData$refs.data.length; i++) { |
|
|
|
|
|
tableData$refs.data[i].index = i + 1 |
|
|
|
|
|
} |
|
|
|
|
|
return true |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
// 如果存在序号字段,则将序号按排序生成,从1开始数
|
|
|
|
|
|
if (indexColumn) { |
|
|
|
|
|
for (let i = 0; i < tableData$refs.data.length; i++) { |
|
|
|
|
|
tableData$refs.data[i][indexColumn] = i + 1 |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// 清除选中状态
|
|
|
tableData$refs.clearSelection() |
|
|
tableData$refs.clearSelection() |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|