update Table
update Table
This commit is contained in:
parent
012cbf285f
commit
891700ae0c
4 changed files with 91 additions and 51 deletions
|
@ -1,6 +1,6 @@
|
||||||
export default {
|
export default {
|
||||||
methods: {
|
methods: {
|
||||||
alignCls (column, type, row = {}) {
|
alignCls (column, row = {}) {
|
||||||
let cellClassName = '';
|
let cellClassName = '';
|
||||||
if (row.cellClassName && column.key && row.cellClassName[column.key]) {
|
if (row.cellClassName && column.key && row.cellClassName[column.key]) {
|
||||||
cellClassName = row.cellClassName[column.key];
|
cellClassName = row.cellClassName[column.key];
|
||||||
|
@ -8,7 +8,7 @@ export default {
|
||||||
return [
|
return [
|
||||||
{
|
{
|
||||||
[`${cellClassName}`]: cellClassName, // cell className
|
[`${cellClassName}`]: cellClassName, // cell className
|
||||||
[`${column.className}`]: column.className && type === 'body', // column className
|
[`${column.className}`]: column.className, // column className
|
||||||
[`${this.prefixCls}-column-${column.align}`]: column.align,
|
[`${this.prefixCls}-column-${column.align}`]: column.align,
|
||||||
[`${this.prefixCls}-hidden`]: (this.fixed === 'left' && column.fixed !== 'left') || (this.fixed === 'right' && column.fixed !== 'right') || (!this.fixed && column.fixed && (column.fixed === 'left' || column.fixed === 'right'))
|
[`${this.prefixCls}-hidden`]: (this.fixed === 'left' && column.fixed !== 'left') || (this.fixed === 'right' && column.fixed !== 'right') || (!this.fixed && column.fixed && (column.fixed === 'left' || column.fixed === 'right'))
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
@mouseleave.stop="handleMouseOut(row._index)"
|
@mouseleave.stop="handleMouseOut(row._index)"
|
||||||
@click.stop="clickCurrentRow(row._index)"
|
@click.stop="clickCurrentRow(row._index)"
|
||||||
@dblclick.stop="dblclickCurrentRow(row._index)">
|
@dblclick.stop="dblclickCurrentRow(row._index)">
|
||||||
<td v-for="column in columns" :class="alignCls(column, 'body', row)">
|
<td v-for="column in columns" :class="alignCls(column, row)">
|
||||||
<Cell
|
<Cell
|
||||||
:fixed="fixed"
|
:fixed="fixed"
|
||||||
:prefix-cls="prefixCls"
|
:prefix-cls="prefixCls"
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
</colgroup>
|
</colgroup>
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th v-for="(index, column) in columns" :class="alignCls(column, 'head')">
|
<th v-for="(index, column) in columns" :class="alignCls(column)">
|
||||||
<div :class="cellClasses(column)">
|
<div :class="cellClasses(column)">
|
||||||
<template v-if="column.type === 'selection'"><Checkbox :checked="isSelectAll" @on-change="selectAll"></Checkbox></template>
|
<template v-if="column.type === 'selection'"><Checkbox :checked="isSelectAll" @on-change="selectAll"></Checkbox></template>
|
||||||
<template v-else>
|
<template v-else>
|
||||||
|
|
|
@ -1,18 +1,45 @@
|
||||||
|
<style>
|
||||||
|
.ivu-table .demo-table-info-row td{
|
||||||
|
background-color: #2db7f5;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.ivu-table .demo-table-error-row td{
|
||||||
|
background-color: #ff6600;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.ivu-table td.demo-table-info-column{
|
||||||
|
background-color: #2db7f5;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.ivu-table .demo-table-info-cell-name {
|
||||||
|
background-color: #2db7f5;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.ivu-table .demo-table-info-cell-age {
|
||||||
|
background-color: #ff6600;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.ivu-table .demo-table-info-cell-address {
|
||||||
|
background-color: #187;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
<template>
|
<template>
|
||||||
<i-table border :content="self" :columns="columns7" :data="data6"></i-table>
|
<p>自定义行样式:</p>
|
||||||
|
<!--<i-table :row-class-name="rowClassName" :columns="columns1" :data="data1"></i-table>-->
|
||||||
|
<p>自定义列样式:</p>
|
||||||
|
<i-table :columns="columns9" :data="data1"></i-table>
|
||||||
|
<p>自定义任意单元格样式:</p>
|
||||||
|
<!--<i-table :columns="columns1" :data="data8"></i-table>-->
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
export default {
|
export default {
|
||||||
data () {
|
data () {
|
||||||
return {
|
return {
|
||||||
self: this,
|
columns1: [
|
||||||
columns7: [
|
|
||||||
{
|
{
|
||||||
title: '姓名',
|
title: '姓名',
|
||||||
key: 'name',
|
key: 'name'
|
||||||
render (row, column, index) {
|
|
||||||
return `<Icon type="person"></Icon> <strong>${row.name}</strong>`;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: '年龄',
|
title: '年龄',
|
||||||
|
@ -20,40 +47,25 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: '地址',
|
title: '地址',
|
||||||
key: 'address',
|
key: 'address'
|
||||||
render () {
|
|
||||||
return `
|
|
||||||
<Poptip title="提示标题" content="提示内容" placement="bottom-end">
|
|
||||||
<i-button>click 激活</i-button>
|
|
||||||
</Poptip>
|
|
||||||
`
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: '操作',
|
|
||||||
key: 'action',
|
|
||||||
width: 150,
|
|
||||||
align: 'center',
|
|
||||||
render (row, column, index) {
|
|
||||||
return `
|
|
||||||
<Dropdown trigger="click" style="margin-left: 20px">
|
|
||||||
<a href="javascript:void(0)">
|
|
||||||
click 触发
|
|
||||||
<Icon type="arrow-down-b"></Icon>
|
|
||||||
</a>
|
|
||||||
<Dropdown-menu slot="list">
|
|
||||||
<Dropdown-item>驴打滚</Dropdown-item>
|
|
||||||
<Dropdown-item>炸酱面</Dropdown-item>
|
|
||||||
<Dropdown-item>豆汁儿</Dropdown-item>
|
|
||||||
<Dropdown-item>冰糖葫芦</Dropdown-item>
|
|
||||||
<Dropdown-item>北京烤鸭</Dropdown-item>
|
|
||||||
</Dropdown-menu>
|
|
||||||
</Dropdown><br><br><br><br><br>
|
|
||||||
`;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
data6: [
|
columns9: [
|
||||||
|
{
|
||||||
|
title: '姓名',
|
||||||
|
key: 'name'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '年龄',
|
||||||
|
key: 'age',
|
||||||
|
className: 'demo-table-info-column'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '地址',
|
||||||
|
key: 'address'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
data1: [
|
||||||
{
|
{
|
||||||
name: '王小明',
|
name: '王小明',
|
||||||
age: 18,
|
age: 18,
|
||||||
|
@ -74,18 +86,46 @@
|
||||||
age: 26,
|
age: 26,
|
||||||
address: '深圳市南山区深南大道'
|
address: '深圳市南山区深南大道'
|
||||||
}
|
}
|
||||||
|
],
|
||||||
|
data8: [
|
||||||
|
{
|
||||||
|
name: '王小明',
|
||||||
|
age: 18,
|
||||||
|
address: '北京市朝阳区芍药居'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: '张小刚',
|
||||||
|
age: 25,
|
||||||
|
address: '北京市海淀区西二旗',
|
||||||
|
cellClassName: {
|
||||||
|
age: 'demo-table-info-cell-age',
|
||||||
|
address: 'demo-table-info-cell-address'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: '李小红',
|
||||||
|
age: 30,
|
||||||
|
address: '上海市浦东新区世纪大道'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: '周小伟',
|
||||||
|
age: 26,
|
||||||
|
address: '深圳市南山区深南大道',
|
||||||
|
cellClassName: {
|
||||||
|
name: 'demo-table-info-cell-name'
|
||||||
|
}
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
show (index) {
|
rowClassName (row, index) {
|
||||||
this.$Modal.info({
|
if (index === 1) {
|
||||||
title: '用户信息',
|
return 'demo-table-info-row';
|
||||||
content: `姓名:${this.data6[index].name}<br>年龄:${this.data6[index].age}<br>地址:${this.data6[index].address}`
|
} else if (index === 3) {
|
||||||
})
|
return 'demo-table-error-row';
|
||||||
},
|
}
|
||||||
remove (index) {
|
return '';
|
||||||
this.data6.splice(index, 1);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue