Vue3环境下为Ant Design Vue中table的checkbox加tooltip

记录Vue3环境下为Ant Design Vue中Table的checkbox加tooltip遇到的问题

问题的产生

在工作时遇到一个场景,需要在table的checkbox被禁用的时候提示原因,但是在Ant Desgin Vue文档中并没有发现有相关介绍。

寻找方法

首先我去看了issue中是否有提到相关问题,看了之后发现果然有,于是便看了下其他人的解决方法,感觉大概是重写选择逻辑,但是这样相对复杂,看到后面发现其实在rowSelection参数中还有一个renderCell参数用来渲染勾选框,我以为就可以解决问题了,可是一看后面写的代码我发现它返回的是一个jsx。

const rowSelection = computed<TableRowSelection | null>(() => {
	return {
		...
		renderCell(checked, record, index, node) {
			//被禁用
	      	if (record.disabled) { 
	       		 return <tooltip title="被禁用">{node}</tooltip>;
		    }
	      	return node;
    	},
		...
	};
});

解决问题

但在vue中这样实现有点奇怪,于是我便想在vue中应该怎么写,想了一下我决定自己改一下tooltip然后用tooltip组件包住这个node渲染到节点上。我的Tooltip是这么写的,用component把VNode渲染出来。

<script setup lang="ts">
import {VNode} from "vue";

let props = defineProps<{
	vn: VNode,
	tooltipMessage: string
}>();
</script>

<template>
	<a-tooltip>
		<template #title>{{ props.tooltipMessage }}</template>
		<component :is="props.vn"/>
	</a-tooltip>
</template>

同时我改了下renderCell参数的代码。

const rowSelection = computed<TableRowSelection | null>(() => {
	return {
		...
		renderCell(checked, record, index, node) {
			if (record.bindStatus) {
				//第一个是组件,第二个是组件的props
				return h(CheckBoxTooltip, {vn: node, tooltipMessage: tooltipMessage.value});
			}
			return node;
		},
		...
	};
});

这样便解决了这个问题。
tooltip效果展示

感谢大家阅读,也同样希望大家能提出宝贵意见指正,帮我成长,共同进步,非常感谢!

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

neMew

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值