鼠标悬浮在树组件节点上展示当前节点名称

方法一:使用CSS样式

在树组件的模板中,为每个节点的外层元素绑定一个类名,例如"tree-node",并设置一个自定义属性来保存节点名称。

<el-tree v-if="showCheck" ref="treeRef" :data="treeData" :props="keyProps" :filter-node-method="filterAction" :default-expand-all="expandFlag">
	<template v-slot:default="{ node, data }">
		<span class="custom-tree-node tree-node" :data-label="node.label">
			<el-checkbox-group v-if="!data[keyProps.children]" v-model="checkValue">
				<el-checkbox :label="data[keyProps.value]" :disabled="data.disabled" @change="flag => onCheck(flag, data)">
					{
   {
    node.label }}
				</el-checkbox>
			</el-checkbox-group>
			<span v-else>
				{
   {
    node.label }}
			</span>
		</span>
	</template>
</el-tree>

使用CSS样式来实现鼠标悬浮时显示节点名称的效果。

在CSS样式中,通过::before伪元素来创建一个内容框,然后使用attr(data-label)来获取节点名称,并设置为内容框的内容。通过调整top和left属性来调整弹出框的位置。可以根据需要自定义调整样式。
确保将CSS样式正确应用到树组件的外层容器或适当的父元素上。

:deep(.el-tree) {
   
	.el-tree-node__content {
   
		position: relative;
	}
	.tree-node:hover::before {
   
		content: attr(data-label); /* 设置节点名称内容 */
		position: absolute;
		top: 26px; /* 调整弹出框位置 */
		left: 40px;
		background-color: #fff; /* 弹出框背景色 */
		padding: 4px 8px;
		border: 1px solid #ccc; /* 弹出框边框样式 */
		border-radius: 4px;
		z-index: 999;
	}
}

方法二:(在checkBox绑定)

将提示文本保存在节点数据中,然后在el-checkbox元素上使用v-bind:title指令来绑定节点数据中的提示文本。

<el-tree v-if="showCheck" ref="treeRef" :data="treeData" :props="keyProps" :filter-node-method="filterAction" :default-expand-all="expandFlag">
	<template v-slot:default="{ node, data }">
		<span class="custom-tree-node">
			<el-checkbox-group v-if="!data[keyProps.children]" v-model="checkValue">
				<el-checkbox :label="data[keyProps.value]" :disabled="data.disabled" @change="flag => onCheck(flag, data)" :title="node.label">
					{
   {
    node.label }}
				</el-checkbox>
			</el-checkbox-group>
			<span v-else>
				{
   {
    node.label }}
			</span>
		</span>
	</template>
</el-tree>

方法三:使用tooltip

<el-tree v-if="showCheck" ref="treeRef" :data="treeData" :props="keyProps" :filter-node-method="filterAction" :default-expand-all="expandFlag">
	<template v-slot:default="{ node, data }">
		<span class="custom-tree-node">
			<el-checkbox-group v-if="!data[keyProps.children]" v-model="checkValue">
				<el-checkbox :label="data[keyProps.value]" :disabled="data.disabled" @change="flag => onCheck(flag, data)">
					<el-tooltip class="item" effect="dark" :content="node.label" placement="bottom-start" show-after="300">
						<template>
							<span>{
   {
    node.label }}</span>
						</template>
					</el-tooltip>
				</el-checkbox>
			</el-checkbox-group>
			<span v-else>
				<el-tooltip class="item" effect="dark" :content="node.label" placement="bottom-start" show-after="300">
					<template>
						<span>{
   {
    node.label }}</span>
					</template>
				</el-tooltip>
			</span>
		</span>
	</template>
</el-tree>

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-23 07:38:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-23 07:38:03       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-23 07:38:03       87 阅读
  4. Python语言-面向对象

    2023-12-23 07:38:03       96 阅读

热门阅读

  1. Linux基础 - Linux ARM 原子读写

    2023-12-23 07:38:03       54 阅读
  2. [node] Node.js的全局对象Global

    2023-12-23 07:38:03       48 阅读
  3. ip addr和ifconfig区别

    2023-12-23 07:38:03       62 阅读
  4. vue3 H5项目中实现PDF预览

    2023-12-23 07:38:03       57 阅读
  5. 面试经典150题(42-44)

    2023-12-23 07:38:03       55 阅读
  6. Vue中转换HTML为PDF

    2023-12-23 07:38:03       59 阅读
  7. NPM介绍与使用

    2023-12-23 07:38:03       56 阅读
  8. SRE 与 DevOps 的不同之处

    2023-12-23 07:38:03       59 阅读
  9. Google 提示:切忌滥用 DORA 指标

    2023-12-23 07:38:03       48 阅读
  10. 力扣labuladong——一刷day77

    2023-12-23 07:38:03       50 阅读