ant-design-vue版本:~1.3.8
需求:表格实现跨行合并,并且在合并完的单元格中显示图片
效果图:
源码:
export default {
data() {
return {
pic95: require('@/assets/produit/95.png'),
pic99: require('@/assets/produit/99.png'),
varTable: {
cloumns: [
{
title: '置信度',
dataIndex: 'confidence ',
class: 'confidence',
customRender: (value, row, index) => {
let obj = {
children: '',
attrs: {}
}
if (index === 0) {
obj = {
children: <div class="risk-pic"><img src={this.pic95} /></div>,
attrs: { rowSpan: 4 }
}
}
if (index === 4) {
obj = {
children: <div class="risk-pic"><img src={this.pic99} /></div>,
attrs: { rowSpan: 4 }
}
}
if ([1, 2, 3, 5, 6, 7].indexOf(index) !== -1) {
obj.attrs.colSpan = 0
}
return obj
}
},
{
title: '天数',
dataIndex: 'window_length',
width: '25%',
customRender: (text) => text + '日'
},
{
title: 'VaR(万元)',
dataIndex: 'var',
width: '25%'
},
{
title: 'VaR/净资产',
dataIndex: 'var_rate',
width: '25%',
customRender: (text) => fmtRatio(text, 2)
}
],
data: [
{window_length: 1, var: 151.69, var_rate: 0.01858},
{window_length: 5, var: 298.94, var_rate: 0.03661},
{window_length: 10, var: 416.70, var_rate: 0.05104},
{window_length: 20, var: 576.04, var_rate: 0.07055},
{window_length: 1, var: 370.64, var_rate: 0.045398},
{window_length: 5, var: 463.33, var_rate: 0.056751},
{window_length: 10, var: 632.91, var_rate: 0.077523},
{window_length: 20, var: 1233.95, var_rate: 0.15114}
]
}
}
},
methods:{
// 百分数设置
fmtRatio(val, index, def) {
// index默认值为2
var index = arguments[1] "color: #ff0000">补充知识:ant-design vue table 可选列、自定义列实现
实现ant-design for vue 自定义列实现。点击按钮,弹窗显示所有列的checkbox,选择checkbox,确定即可实现自定义列。先上代码
<script>
/**
* 该组件为实现table可选列。
* 具体操作见下方注释。
* 全部集成原a-table功能,使用方式与原a-table完全相同,扩展增加了可选列功能
* 该组件已注册至全局,使用方式只需将a-table变为zyx-table即可,等等一系列原写法不变,即可增加该功能.
* 采用rander函数模式写,为了实现a-table中slot可动态。
*/
export default {
name: 'Table',
data () {
return {
modalVisible: false, // 弹窗
columns: [], // 表格的列,根据条件来操作该字段
selectList: [], // 已选择的列
temporarySelectData: [], // 暂时选择的列,点击checkbox暂存到该字段,点确定同步到selectList
checkboxList: []// checkbox的list,也做总数据来使用
}
},
mounted () {
/**
* 挂载后,将原columns复制到本页columns,checkboxList
* 将selectList赋值全选状态
*/
this.columns = this.deepClone(this.$attrs.columns)
this.checkboxList = this.deepClone(this.$attrs.columns)
this.selectList = this.columns.map(ele => ele.dataIndex)
},
methods: {
/**
* 打开modal,将checkbox默认值或者是选择值(暂存)重新赋值
*/
handelOpenSelect () {
this.temporarySelectData = this.deepClone(this.selectList)
this.modalVisible = true
},
/**
* 点击确定,将暂存值赋值(temporarySelectData)给已选择的列(selectList)
* 将列(columns)根据已选择的列(selectList)筛选出来
*/
handleOk () {
this.selectList = this.deepClone(this.temporarySelectData)
this.modalVisible = false
this.columns = this.checkboxList.filter(ele => this.selectList.includes(ele.dataIndex))
},
handleCancel () {
this.modalVisible = false
},
handelChange (e) {
this.temporarySelectData = this.deepClone(e)
},
deepClone (target) {
let result
if (typeof target === 'object') {
if (Array.isArray(target)) {
result = []
for (const i in target) {
result.push(this.deepClone(target[i]))
}
} else if (target === null) {
result = null
} else if (target.constructor === RegExp) {
result = target
} else {
result = {}
for (const i in target) {
result[i] = this.deepClone(target[i])
}
}
} else {
result = target
}
return result
}
},
render () {
const props = { ...this.$attrs, ...this.$props, ...{ columns: this.columns } }
const on = { ...this.$listeners }
const slots = Object.keys(this.$slots).map(slot => {
return (
<template slot={slot}>{ this.$slots[slot] }</template>
)
})
const table = (
<a-table props={props} scopedSlots={ this.$scopedSlots } on={on} ref="zyxTable">
{slots}
</a-table>
)
const changeDiv = (
<a-button class="select-columns" size="small" onClick={this.handelOpenSelect}>列</a-button>
)
const checkboxArr = []
for (let i = 0; i < this.checkboxList.length; i++) {
checkboxArr.push(<a-col span={8}><a-checkbox value={this.checkboxList[i].dataIndex}>{this.checkboxList[i].title}</a-checkbox></a-col>)
}
const modal = (
<a-modal
title="设置列"
visible={this.modalVisible}
onOk={this.handleOk}
onCancel={this.handleCancel}>
<a-checkbox-group value={this.temporarySelectData} onChange={this.handelChange}>
<a-row>
{checkboxArr}
</a-row>
</a-checkbox-group>
</a-modal>
)
return (
<div class="zyx-table">
{ table }
{ changeDiv }
{ modal }
</div>
)
}
}
</script>
<style lang="less" scoped>
.zyx-table{
position: relative;
margin-top: 20px;
.select-columns{
position: absolute;
right: 0;
top: -30px;
}
}
.ant-row{
width: 100%;
.ant-col-8{
margin-bottom: 10px;
}
}
.ant-checkbox-group{
width: 100%;
}
</style>
该组件二次封装了a-table,集成原a-table所有方法
使用方法,在全局注册该组件,将原a-table替换为zyx-table即可实现。
将原标签替换为rander函数,是为了实现slot动态传入的效果。
有疑问或者更好的建议,欢迎光临思密达。github传送门
以上这篇antd vue table跨行合并单元格,并且自定义内容实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
