Vue3中为Ant Design Vue中table的checkbox加tooltip、popover

问题的产生

Vue版本:3.3.13

ant-design-vue 版本:3.x.x

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

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

typescript 复制代码
const rowSelection = computed<TableRowSelection | null>(() => {
	return {
		...
		renderCell(checked, record, index, node) {
			//被禁用
	      	if (record.disabled) { 
	       		 return <tooltip title="被禁用">{node}</tooltip>;
		    }
	      	return node;
    	},
		...
	};
});
解决方法

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

vue 复制代码
# SelectionCheckboxTooltip.vue
<script setup lang="ts">
import {VNode} from 'vue';

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

<template>
  <a-popover>
    <template #title>
      提示
    </template>
    <template #content>
      {{ props.tooltipMessage }}
    </template>
    <component :is="props.vn" />
  </a-popover>
</template>同时我改了下 renderCell 参数的代码。
typescript 复制代码
/**
 * @description ant-table row 多选
 */
const rowSelection = computed(() => {
  return {
    ...
    renderCell: (_checked: boolean, record: any, _index: number, node: VNode) => {
      //被禁用的
      if (xxxx) {
        //第一个是组件,第二个是组件的props
        return h(SelectionCheckboxTooltip, {vn: node, tooltipMessage: '被禁用'});
      }
      return node;
    },
    getCheckboxProps: (record: any) => ({
      disabled: xxxx,
    }),
    ...
  };
});

问题解决,特此记录!

相关推荐
qiyi.sky几秒前
JavaWeb——Vue组件库Element(3/6):常见组件:Dialog对话框、Form表单(介绍、使用、实际效果)
前端·javascript·vue.js
煸橙干儿~~4 分钟前
分析JS Crash(进程崩溃)
java·前端·javascript
哪 吒6 分钟前
华为OD机试 - 几何平均值最大子数(Python/JS/C/C++ 2024 E卷 200分)
javascript·python·华为od
安冬的码畜日常13 分钟前
【D3.js in Action 3 精译_027】3.4 让 D3 数据适应屏幕(下)—— D3 分段比例尺的用法
前端·javascript·信息可视化·数据可视化·d3.js·d3比例尺·分段比例尺
杨荧32 分钟前
【JAVA开源】基于Vue和SpringBoot的洗衣店订单管理系统
java·开发语言·vue.js·spring boot·spring cloud·开源
l1x1n040 分钟前
No.3 笔记 | Web安全基础:Web1.0 - 3.0 发展史
前端·http·html
Q_w77421 小时前
一个真实可用的登录界面!
javascript·mysql·php·html5·网站登录
昨天;明天。今天。1 小时前
案例-任务清单
前端·javascript·css
一丝晨光1 小时前
C++、Ruby和JavaScript
java·开发语言·javascript·c++·python·c·ruby
Front思1 小时前
vue使用高德地图
javascript·vue.js·ecmascript