fix render to customRender
parent
f65c72f62b
commit
a9e51adde6
|
@ -10,13 +10,29 @@ Simple table with actions.
|
||||||
|
|
||||||
```html
|
```html
|
||||||
<template>
|
<template>
|
||||||
<a-table :columns="columns" :dataSource="data" />
|
<a-table :columns="columns" :dataSource="data">
|
||||||
|
<template slot="name" slot-scope="text">
|
||||||
|
<a href="#">{{text}}</a>
|
||||||
|
</template>
|
||||||
|
<template slot="action" slot-scope="text, record">
|
||||||
|
<span>
|
||||||
|
<a href="#">Action 一 {{record.name}}</a>
|
||||||
|
<a-divider type="vertical" />
|
||||||
|
<a href="#">Delete</a>
|
||||||
|
<a-divider type="vertical" />
|
||||||
|
<a href="#" class="ant-dropdown-link">
|
||||||
|
More actions <a-icon type="down" />
|
||||||
|
</a>
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
</a-table>
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
const columns = [{
|
const columns = [{
|
||||||
title: 'Name',
|
title: 'Name',
|
||||||
dataIndex: 'name',
|
dataIndex: 'name',
|
||||||
key: 'name',
|
key: 'name',
|
||||||
|
slotScopeName: 'name',
|
||||||
}, {
|
}, {
|
||||||
title: 'Age',
|
title: 'Age',
|
||||||
dataIndex: 'age',
|
dataIndex: 'age',
|
||||||
|
@ -28,6 +44,7 @@ const columns = [{
|
||||||
}, {
|
}, {
|
||||||
title: 'Action',
|
title: 'Action',
|
||||||
key: 'action',
|
key: 'action',
|
||||||
|
slotScopeName: 'action',
|
||||||
}];
|
}];
|
||||||
|
|
||||||
const data = [{
|
const data = [{
|
||||||
|
|
|
@ -0,0 +1,88 @@
|
||||||
|
<cn>
|
||||||
|
#### template 风格的 API
|
||||||
|
使用 template 风格的 API
|
||||||
|
> 这个只是一个描述 `columns` 的语法糖,所以你不能用其他组件去包裹 `Column` 和 `ColumnGroup`。
|
||||||
|
</cn>
|
||||||
|
|
||||||
|
<us>
|
||||||
|
#### template style API
|
||||||
|
Using template style API
|
||||||
|
> Since this is just a syntax sugar for the prop `columns`, so that you can't compose `Column` and `ColumnGroup` with other Components.
|
||||||
|
</us>
|
||||||
|
|
||||||
|
```html
|
||||||
|
<template>
|
||||||
|
<a-table :dataSource="data">
|
||||||
|
<a-table-column-group>
|
||||||
|
<span slot="title" style="color: #1890ff">Name</span>
|
||||||
|
<a-table-column
|
||||||
|
dataIndex="firstName"
|
||||||
|
key="firstName"
|
||||||
|
>
|
||||||
|
<span slot="title" style="color: #1890ff">First Name</span>
|
||||||
|
</a-table-column>
|
||||||
|
<a-table-column
|
||||||
|
title="Last Name"
|
||||||
|
dataIndex="lastName"
|
||||||
|
key="lastName"
|
||||||
|
/>
|
||||||
|
</a-table-column-group>
|
||||||
|
<a-table-column
|
||||||
|
title="Age"
|
||||||
|
dataIndex="age"
|
||||||
|
key="age"
|
||||||
|
/>
|
||||||
|
<a-table-column
|
||||||
|
title="Address"
|
||||||
|
dataIndex="address"
|
||||||
|
key="address"
|
||||||
|
/>
|
||||||
|
<a-table-column
|
||||||
|
title="Action"
|
||||||
|
key="action"
|
||||||
|
>
|
||||||
|
<template slot-scope="text, record">
|
||||||
|
<span>
|
||||||
|
<a href="#">Action 一 {{record.firstName}}</a>
|
||||||
|
<a-divider type="vertical" />
|
||||||
|
<a href="#">Delete</a>
|
||||||
|
<a-divider type="vertical" />
|
||||||
|
<a href="#" class="ant-dropdown-link">
|
||||||
|
More actions <a-icon type="down" />
|
||||||
|
</a>
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
</a-table-column>
|
||||||
|
</a-table>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
|
||||||
|
const data = [{
|
||||||
|
key: '1',
|
||||||
|
firstName: 'John',
|
||||||
|
lastName: 'Brown',
|
||||||
|
age: 32,
|
||||||
|
address: 'New York No. 1 Lake Park',
|
||||||
|
}, {
|
||||||
|
key: '2',
|
||||||
|
firstName: 'Jim',
|
||||||
|
lastName: 'Green',
|
||||||
|
age: 42,
|
||||||
|
address: 'London No. 1 Lake Park',
|
||||||
|
}, {
|
||||||
|
key: '3',
|
||||||
|
firstName: 'Joe',
|
||||||
|
lastName: 'Black',
|
||||||
|
age: 32,
|
||||||
|
address: 'Sidney No. 1 Lake Park',
|
||||||
|
}];
|
||||||
|
|
||||||
|
export default {
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
data,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
```
|
|
@ -1,5 +1,80 @@
|
||||||
import Table from './Table'
|
import T from './Table'
|
||||||
|
|
||||||
export * from './interface'
|
import { getOptionProps, getKey, getClass,
|
||||||
|
getStyle, getEvents, getSlotOptions, camelize, getSlots,
|
||||||
|
} from '../_util/props-util'
|
||||||
|
const Table = {
|
||||||
|
name: 'Table',
|
||||||
|
Column: T.Column,
|
||||||
|
ColumnGroup: T.ColumnGroup,
|
||||||
|
props: T.props,
|
||||||
|
methods: {
|
||||||
|
normalize (elements = []) {
|
||||||
|
const columns = []
|
||||||
|
elements.forEach(element => {
|
||||||
|
if (!element.tag) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
const key = getKey(element)
|
||||||
|
const style = getStyle(element)
|
||||||
|
const cls = getClass(element)
|
||||||
|
const props = getOptionProps(element)
|
||||||
|
const events = getEvents(element)
|
||||||
|
const listeners = {}
|
||||||
|
Object.keys(events).forEach(e => {
|
||||||
|
const k = `on_${e}`
|
||||||
|
listeners[camelize(k)] = events[e]
|
||||||
|
})
|
||||||
|
const { default: children, title } = getSlots(element)
|
||||||
|
const column = { title, ...props, style, class: cls, ...listeners }
|
||||||
|
if (key) {
|
||||||
|
column.key = key
|
||||||
|
}
|
||||||
|
if (getSlotOptions(element).__ANT_TABLE_COLUMN_GROUP) {
|
||||||
|
column.children = this.normalize(children)
|
||||||
|
} else {
|
||||||
|
const customRender = element.data && element.data.scopedSlots && element.data.scopedSlots.default
|
||||||
|
column.customRender = column.customRender || customRender
|
||||||
|
}
|
||||||
|
columns.push(column)
|
||||||
|
})
|
||||||
|
return columns
|
||||||
|
},
|
||||||
|
updateColumns (cols = []) {
|
||||||
|
const columns = []
|
||||||
|
const { $slots, $scopedSlots } = this
|
||||||
|
cols.forEach(col => {
|
||||||
|
const { slotTitle, slotScopeName, ...restProps } = col
|
||||||
|
const column = {
|
||||||
|
...restProps,
|
||||||
|
title: col.title || $slots[slotTitle],
|
||||||
|
}
|
||||||
|
if (slotScopeName && $scopedSlots[slotScopeName]) {
|
||||||
|
column.customRender = column.customRender || $scopedSlots[slotScopeName]
|
||||||
|
}
|
||||||
|
if (col.children) {
|
||||||
|
column.children = this.updateColumns(column.children)
|
||||||
|
}
|
||||||
|
columns.push(column)
|
||||||
|
})
|
||||||
|
return columns
|
||||||
|
},
|
||||||
|
},
|
||||||
|
render () {
|
||||||
|
const { $listeners, $slots, normalize } = this
|
||||||
|
const props = getOptionProps(this)
|
||||||
|
const columns = props.columns ? this.updateColumns(props.columns) : normalize($slots.default)
|
||||||
|
const tProps = {
|
||||||
|
props: {
|
||||||
|
...props,
|
||||||
|
columns,
|
||||||
|
},
|
||||||
|
on: $listeners,
|
||||||
|
}
|
||||||
|
return (
|
||||||
|
<T {...tProps}/>
|
||||||
|
)
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
export default Table
|
export default Table
|
||||||
|
|
|
@ -17,7 +17,7 @@ export const ColumnProps = {
|
||||||
title: PropTypes.any,
|
title: PropTypes.any,
|
||||||
// key?: React.Key;
|
// key?: React.Key;
|
||||||
dataIndex: PropTypes.string,
|
dataIndex: PropTypes.string,
|
||||||
render: PropTypes.func,
|
customRender: PropTypes.func,
|
||||||
filters: PropTypes.arrayOf(ColumnFilterItem),
|
filters: PropTypes.arrayOf(ColumnFilterItem),
|
||||||
// onFilter: (value: any, record: T) => PropTypes.bool,
|
// onFilter: (value: any, record: T) => PropTypes.bool,
|
||||||
filterMultiple: PropTypes.bool,
|
filterMultiple: PropTypes.bool,
|
||||||
|
|
|
@ -22,7 +22,7 @@ export default {
|
||||||
{
|
{
|
||||||
title: 'Operations', dataIndex: '',
|
title: 'Operations', dataIndex: '',
|
||||||
className: 'd',
|
className: 'd',
|
||||||
key: 'd', render () {
|
key: 'd', customRender () {
|
||||||
return <a href='#'>Operations</a>
|
return <a href='#'>Operations</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -3,7 +3,7 @@ import Table from '../index'
|
||||||
import '../assets/index.less'
|
import '../assets/index.less'
|
||||||
|
|
||||||
const columns = [
|
const columns = [
|
||||||
{ title: '手机号', dataIndex: 'a', colSpan: 2, width: 100, key: 'a', render (h, o, row, index) {
|
{ title: '手机号', dataIndex: 'a', colSpan: 2, width: 100, key: 'a', customRender (o, row, index) {
|
||||||
const obj = {
|
const obj = {
|
||||||
children: o,
|
children: o,
|
||||||
props: {},
|
props: {},
|
||||||
|
@ -22,7 +22,7 @@ const columns = [
|
||||||
}
|
}
|
||||||
return obj
|
return obj
|
||||||
} },
|
} },
|
||||||
{ title: '电话', dataIndex: 'b', colSpan: 0, width: 100, key: 'b', render (h, o, row, index) {
|
{ title: '电话', dataIndex: 'b', colSpan: 0, width: 100, key: 'b', customRender (o, row, index) {
|
||||||
const obj = {
|
const obj = {
|
||||||
children: o,
|
children: o,
|
||||||
props: {},
|
props: {},
|
||||||
|
@ -33,7 +33,7 @@ const columns = [
|
||||||
}
|
}
|
||||||
return obj
|
return obj
|
||||||
} },
|
} },
|
||||||
{ title: 'Name', dataIndex: 'c', width: 100, key: 'c', render (h, o, row, index) {
|
{ title: 'Name', dataIndex: 'c', width: 100, key: 'c', customRender (o, row, index) {
|
||||||
const obj = {
|
const obj = {
|
||||||
children: o,
|
children: o,
|
||||||
props: {},
|
props: {},
|
||||||
|
@ -44,7 +44,7 @@ const columns = [
|
||||||
}
|
}
|
||||||
return obj
|
return obj
|
||||||
} },
|
} },
|
||||||
{ title: 'Address', dataIndex: 'd', width: 200, key: 'd', render (h, o, row, index) {
|
{ title: 'Address', dataIndex: 'd', width: 200, key: 'd', customRender (o, row, index) {
|
||||||
const obj = {
|
const obj = {
|
||||||
children: o,
|
children: o,
|
||||||
props: {},
|
props: {},
|
||||||
|
@ -58,7 +58,7 @@ const columns = [
|
||||||
|
|
||||||
return obj
|
return obj
|
||||||
} },
|
} },
|
||||||
{ title: 'Gender', dataIndex: 'e', width: 200, key: 'e', render (h, o, row, index) {
|
{ title: 'Gender', dataIndex: 'e', width: 200, key: 'e', customRender (o, row, index) {
|
||||||
const obj = {
|
const obj = {
|
||||||
children: o,
|
children: o,
|
||||||
props: {},
|
props: {},
|
||||||
|
@ -70,7 +70,7 @@ const columns = [
|
||||||
} },
|
} },
|
||||||
{
|
{
|
||||||
title: 'Operations', dataIndex: '', key: 'f',
|
title: 'Operations', dataIndex: '', key: 'f',
|
||||||
render (h, o, row, index) {
|
customRender (o, row, index) {
|
||||||
if (index === 5) {
|
if (index === 5) {
|
||||||
return {
|
return {
|
||||||
props: {
|
props: {
|
||||||
|
|
|
@ -24,7 +24,7 @@ export default {
|
||||||
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
{
|
{
|
||||||
title: 'Operations', dataIndex: '', key: 'd', render () {
|
title: 'Operations', dataIndex: '', key: 'd', customRender () {
|
||||||
return <a href='#'>Operations</a>
|
return <a href='#'>Operations</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -19,7 +19,7 @@ export default {
|
||||||
{ title: 'title 1', dataIndex: 'a', key: 'a', width: 100 },
|
{ title: 'title 1', dataIndex: 'a', key: 'a', width: 100 },
|
||||||
{ title: 'title 2', dataIndex: 'b', key: 'b', width: 100 },
|
{ title: 'title 2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
{ title: 'title 3', dataIndex: 'c', key: 'c', width: 200 },
|
{ title: 'title 3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
{ title: 'Operation', dataIndex: '', key: 'x', render: this.renderAction },
|
{ title: 'Operation', dataIndex: '', key: 'x', customRender: this.renderAction },
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
|
@ -2,22 +2,6 @@
|
||||||
import Table from '../index'
|
import Table from '../index'
|
||||||
import '../assets/index.less'
|
import '../assets/index.less'
|
||||||
|
|
||||||
const columns = [
|
|
||||||
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100, fixed: 'left' },
|
|
||||||
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100, fixed: 'left' },
|
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c' },
|
|
||||||
{ title: 'title4', dataIndex: 'b', key: 'd' },
|
|
||||||
{ title: 'title5', dataIndex: 'b', key: 'e' },
|
|
||||||
{ title: 'title6', dataIndex: 'b', key: 'f',
|
|
||||||
render: (h) => <div style={{ height: '40px', lineHeight: '40px' }}>我很高</div> },
|
|
||||||
{ title: 'title7', dataIndex: 'b', key: 'g' },
|
|
||||||
{ title: 'title8', dataIndex: 'b', key: 'h' },
|
|
||||||
{ title: 'title9', dataIndex: 'b', key: 'i' },
|
|
||||||
{ title: 'title10', dataIndex: 'b', key: 'j' },
|
|
||||||
{ title: 'title11', dataIndex: 'b', key: 'k' },
|
|
||||||
{ title: 'title12', dataIndex: 'b', key: 'l', width: 100, fixed: 'right' },
|
|
||||||
]
|
|
||||||
|
|
||||||
const data = [
|
const data = [
|
||||||
{ a: '123', b: 'xxxxxxxx', d: 3, key: '1', title: 'hello' },
|
{ a: '123', b: 'xxxxxxxx', d: 3, key: '1', title: 'hello' },
|
||||||
{ a: 'cdd', b: 'edd12221', d: 3, key: '2', title: 'hello' },
|
{ a: 'cdd', b: 'edd12221', d: 3, key: '2', title: 'hello' },
|
||||||
|
@ -36,6 +20,21 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
render () {
|
render () {
|
||||||
|
const columns = [
|
||||||
|
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100, fixed: 'left' },
|
||||||
|
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100, fixed: 'left' },
|
||||||
|
{ title: 'title3', dataIndex: 'c', key: 'c' },
|
||||||
|
{ title: 'title4', dataIndex: 'b', key: 'd' },
|
||||||
|
{ title: 'title5', dataIndex: 'b', key: 'e' },
|
||||||
|
{ title: 'title6', dataIndex: 'b', key: 'f',
|
||||||
|
customRender: () => <div style={{ height: '40px', lineHeight: '40px' }}>我很高</div> },
|
||||||
|
{ title: 'title7', dataIndex: 'b', key: 'g' },
|
||||||
|
{ title: 'title8', dataIndex: 'b', key: 'h' },
|
||||||
|
{ title: 'title9', dataIndex: 'b', key: 'i' },
|
||||||
|
{ title: 'title10', dataIndex: 'b', key: 'j' },
|
||||||
|
{ title: 'title11', dataIndex: 'b', key: 'k' },
|
||||||
|
{ title: 'title12', dataIndex: 'b', key: 'l', width: 100, fixed: 'right' },
|
||||||
|
]
|
||||||
return (
|
return (
|
||||||
<div style={{ width: '800px' }}>
|
<div style={{ width: '800px' }}>
|
||||||
<h2>Fixed columns</h2>
|
<h2>Fixed columns</h2>
|
||||||
|
|
|
@ -44,7 +44,7 @@ export default {
|
||||||
key='d'
|
key='d'
|
||||||
// render={() => <a href='#'>Operations</a>}
|
// render={() => <a href='#'>Operations</a>}
|
||||||
scopedSlots= {
|
scopedSlots= {
|
||||||
{ render: () => <a href='#'>Operations</a> }
|
{ default: () => <a href='#'>Operations</a> }
|
||||||
}
|
}
|
||||||
>
|
>
|
||||||
</Column>
|
</Column>
|
||||||
|
|
|
@ -20,24 +20,24 @@ export default {
|
||||||
this.remove(index)
|
this.remove(index)
|
||||||
},
|
},
|
||||||
|
|
||||||
checkbox (h, a) {
|
checkbox (a) {
|
||||||
return <label>
|
return <label>
|
||||||
<input type='checkbox' />
|
<input type='checkbox' />
|
||||||
{a}
|
{a}
|
||||||
</label>
|
</label>
|
||||||
},
|
},
|
||||||
|
|
||||||
renderAction (h, o, row, index) {
|
renderAction (o, row, index) {
|
||||||
return <a href='javascript:;' onClick={() => this.handleClick(index)}>Delete</a>
|
return <a href='javascript:;' onClick={() => this.handleClick(index)}>Delete</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
render () {
|
render () {
|
||||||
const columns = [
|
const columns = [
|
||||||
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100, render: this.checkbox },
|
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100, customRender: this.checkbox },
|
||||||
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
{ title: 'Operations', dataIndex: '', key: 'x', render: this.renderAction },
|
{ title: 'Operations', dataIndex: '', key: 'x', customRender: this.renderAction },
|
||||||
]
|
]
|
||||||
return (
|
return (
|
||||||
<Table columns={columns} data={this.data} class='table' rowKey={record => record.a} />
|
<Table columns={columns} data={this.data} class='table' rowKey={record => record.a} />
|
||||||
|
|
|
@ -11,7 +11,7 @@ export default {
|
||||||
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
{
|
{
|
||||||
title: 'Operations', dataIndex: '', key: 'd', render () {
|
title: 'Operations', dataIndex: '', key: 'd', customRender () {
|
||||||
return <a href='#'>Operations</a>
|
return <a href='#'>Operations</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -33,7 +33,7 @@ export default {
|
||||||
title: <a onClick={this.toggleBody} href='javascript:;'>{this.showBody ? '隐藏' : '显示'}体</a>,
|
title: <a onClick={this.toggleBody} href='javascript:;'>{this.showBody ? '隐藏' : '显示'}体</a>,
|
||||||
key: 'x',
|
key: 'x',
|
||||||
width: 200,
|
width: 200,
|
||||||
render () {
|
customRender () {
|
||||||
return <a href='#'>Operations</a>
|
return <a href='#'>Operations</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,20 +1,6 @@
|
||||||
import Table from '../index'
|
import Table from '../index'
|
||||||
import '../assets/index.less'
|
import '../assets/index.less'
|
||||||
|
|
||||||
const columns = [
|
|
||||||
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100 },
|
|
||||||
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
|
||||||
{
|
|
||||||
title: 'Operations',
|
|
||||||
dataIndex: '',
|
|
||||||
key: 'd',
|
|
||||||
render (h) {
|
|
||||||
return <a href='#'>Operations</a>
|
|
||||||
},
|
|
||||||
},
|
|
||||||
]
|
|
||||||
|
|
||||||
const data = [
|
const data = [
|
||||||
{ a: '123', key: '1' },
|
{ a: '123', key: '1' },
|
||||||
{ a: 'cdd', b: 'edd', key: '2' },
|
{ a: 'cdd', b: 'edd', key: '2' },
|
||||||
|
@ -23,6 +9,19 @@ const data = [
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
render () {
|
render () {
|
||||||
|
const columns = [
|
||||||
|
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100 },
|
||||||
|
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
|
{
|
||||||
|
title: 'Operations',
|
||||||
|
dataIndex: '',
|
||||||
|
key: 'd',
|
||||||
|
customRender () {
|
||||||
|
return <a href='#'>Operations</a>
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
const row = {
|
const row = {
|
||||||
render () {
|
render () {
|
||||||
return <tr style={{ color: 'red' }}>{this.$slots.default}</tr>
|
return <tr style={{ color: 'red' }}>{this.$slots.default}</tr>
|
||||||
|
|
|
@ -41,7 +41,7 @@ export default {
|
||||||
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
{ title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
{
|
{
|
||||||
title: 'Operations', dataIndex: '', key: 'x', render: (h, text, record) => {
|
title: 'Operations', dataIndex: '', key: 'x', customRender: (text, record) => {
|
||||||
return <a href='javascript:;' onClick={e => this.handleClick(record, e)}>click {record.a}</a>
|
return <a href='javascript:;' onClick={e => this.handleClick(record, e)}>click {record.a}</a>
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
|
@ -2,17 +2,6 @@
|
||||||
import Table from '../index'
|
import Table from '../index'
|
||||||
import '../assets/index.less'
|
import '../assets/index.less'
|
||||||
|
|
||||||
const columns = [
|
|
||||||
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100 },
|
|
||||||
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
|
||||||
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
|
||||||
{
|
|
||||||
title: 'Operations', dataIndex: '', key: 'd', render (h) {
|
|
||||||
return <a href='#'>Operations</a>
|
|
||||||
},
|
|
||||||
},
|
|
||||||
]
|
|
||||||
|
|
||||||
const data = [
|
const data = [
|
||||||
{ a: '123', key: '1' },
|
{ a: '123', key: '1' },
|
||||||
{ a: 'cdd', b: 'edd', key: '2' },
|
{ a: 'cdd', b: 'edd', key: '2' },
|
||||||
|
@ -21,6 +10,16 @@ const data = [
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
render () {
|
render () {
|
||||||
|
const columns = [
|
||||||
|
{ title: 'title1', dataIndex: 'a', key: 'a', width: 100 },
|
||||||
|
{ id: '123', title: 'title2', dataIndex: 'b', key: 'b', width: 100 },
|
||||||
|
{ title: 'title3', dataIndex: 'c', key: 'c', width: 200 },
|
||||||
|
{
|
||||||
|
title: 'Operations', dataIndex: '', key: 'd', customRender () {
|
||||||
|
return <a href='#'>Operations</a>
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<h2>title and footer</h2>
|
<h2>title and footer</h2>
|
||||||
|
|
|
@ -34,8 +34,8 @@ const Table = {
|
||||||
if (getSlotOptions(element).isTableColumnGroup) {
|
if (getSlotOptions(element).isTableColumnGroup) {
|
||||||
column.children = this.normalize(children)
|
column.children = this.normalize(children)
|
||||||
} else {
|
} else {
|
||||||
const render = element.data && element.data.scopedSlots && element.data.scopedSlots.render
|
const customRender = element.data && element.data.scopedSlots && element.data.scopedSlots.default
|
||||||
column.render = column.render || render
|
column.customRender = column.customRender || customRender
|
||||||
}
|
}
|
||||||
columns.push(column)
|
columns.push(column)
|
||||||
})
|
})
|
||||||
|
|
|
@ -15,7 +15,7 @@ export default {
|
||||||
'left',
|
'left',
|
||||||
'right',
|
'right',
|
||||||
]),
|
]),
|
||||||
render: PropTypes.func,
|
customRender: PropTypes.func,
|
||||||
className: PropTypes.string,
|
className: PropTypes.string,
|
||||||
// onCellClick: PropTypes.func,
|
// onCellClick: PropTypes.func,
|
||||||
// onCell: PropTypes.func,
|
// onCell: PropTypes.func,
|
||||||
|
|
|
@ -122,7 +122,7 @@ const ExpandableTable = {
|
||||||
rows[0].unshift({ ...iconColumn, column: iconColumn })
|
rows[0].unshift({ ...iconColumn, column: iconColumn })
|
||||||
},
|
},
|
||||||
|
|
||||||
renderExpandedRow (record, index, render, className, ancestorKeys, indent, fixed) {
|
renderExpandedRow (record, index, expandedRowRender, className, ancestorKeys, indent, fixed) {
|
||||||
const { prefixCls, expandIconAsCell, indentSize } = this
|
const { prefixCls, expandIconAsCell, indentSize } = this
|
||||||
let colCount
|
let colCount
|
||||||
if (fixed === 'left') {
|
if (fixed === 'left') {
|
||||||
|
@ -138,7 +138,7 @@ const ExpandableTable = {
|
||||||
props: {
|
props: {
|
||||||
colSpan: colCount,
|
colSpan: colCount,
|
||||||
},
|
},
|
||||||
children: fixed !== 'right' ? render(record, index, indent) : ' ',
|
children: fixed !== 'right' ? expandedRowRender(record, index, indent) : ' ',
|
||||||
}),
|
}),
|
||||||
}]
|
}]
|
||||||
if (expandIconAsCell && fixed !== 'right') {
|
if (expandIconAsCell && fixed !== 'right') {
|
||||||
|
|
|
@ -40,7 +40,7 @@ export default {
|
||||||
column,
|
column,
|
||||||
component: BodyCell,
|
component: BodyCell,
|
||||||
} = this
|
} = this
|
||||||
const { dataIndex, render, className = '' } = column
|
const { dataIndex, customRender, className = '' } = column
|
||||||
const cls = className || column.class
|
const cls = className || column.class
|
||||||
// We should return undefined if no dataIndex is specified, but in order to
|
// We should return undefined if no dataIndex is specified, but in order to
|
||||||
// be compatible with object-path's behavior, we return the record object instead.
|
// be compatible with object-path's behavior, we return the record object instead.
|
||||||
|
@ -63,8 +63,8 @@ export default {
|
||||||
let colSpan
|
let colSpan
|
||||||
let rowSpan
|
let rowSpan
|
||||||
|
|
||||||
if (render) {
|
if (customRender) {
|
||||||
text = render(h, text, record, index)
|
text = customRender(text, record, index)
|
||||||
if (this.isInvalidRenderCellText(text)) {
|
if (this.isInvalidRenderCellText(text)) {
|
||||||
tdProps.attrs = text.attrs || text.props || {}
|
tdProps.attrs = text.attrs || text.props || {}
|
||||||
colSpan = tdProps.attrs.colSpan
|
colSpan = tdProps.attrs.colSpan
|
||||||
|
|
Loading…
Reference in New Issue