element table组件实现show-overflow-tooltip效果,解决一些自带show-overflow-tooltip不能实现的效果。

1. 背景

  • 数据过多并且包含有换行、空格等特殊字符时,在使用el-table-column自带属性show-overflow-tooltip无法将特殊字符表现出来,并且鼠标移入show-overflow-tooltip提示框内提示框并不会一直存在,另外在插槽中使用el-tooltip组件时,会出现文字较少时,鼠标移入也出现了提示的问题。
  • 本篇文章使用插el-table-column插槽解决了上述存在的问题并对相关代码进行了封装,方便多次调用;在数据内容过多时添加Y轴滚动轴,优化了滚动轴样式;
  • 实现效果截图在最后。

2. 过程分析

2. 1 el-table.vue代码片段

  • 使用封装组件tooltip,接收message参数
html 复制代码
<el-table-column align="center" prop="address" label="地址">
	<template slot-scope="scope">
		<tooltip :message="scope.row.address"></tooltip>
	</template>
</el-table-column>

2.2 组件tooltip.vue代码分析

  • 完成代码(包含滚动轴样式处理)
html 复制代码
<template>
	<div>
		<el-tooltip :disabled="isShowTooltip" class="tooltip" placement="top">
			<pre class="tooltip__tip" slot="content">{{ messageWord }}</pre>
			<div class="tooltip__words" @mouseenter="enterEvents">{{ messageWord }}</div>
		</el-tooltip>
	</div>
</template>
<script>
export default {
	data() {
		return {
			messageWord: '',
			isShowTooltip: false
		}
	},
	props: {
		message: {
			required: true
		}
	},
	mounted() {
		this.messageWord = this.message
	},
	methods: {
		enterEvents(e) {
			let tableContentBoxWidth = e.target.getBoundingClientRect().width;
			let tableContentWidth = this.getElementTextWidth(e.target);
			if (tableContentWidth >= tableContentBoxWidth) {
				this.isShowTooltip = false;
			}else{
				this.isShowTooltip = true
			}
		},
		getElementTextWidth(el) {
			const range = new Range();
			range.selectNodeContents(el);
			const width = range.getBoundingClientRect().width;
			return width
		}
	}
}
</script>
<style lang="less" scoped>
.tooltip__words {
	width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.tooltip__tip {
	max-width: 500px;
	max-height: 300px;
	overflow-y: auto;
	white-space: pre-line;
}

.tooltip__tip::-webkit-scrollbar  {
	width: 6px;
	// height: 10px; // 高度写不写,都不影响,因为会根据内容的长度自动计算
}

.tooltip__tip::-webkit-scrollbar-thumb {
	background: #ccc; // 滑块颜色
	border-radius: 3px; // 滑块圆角
}

.tooltip__tip::-webkit-scrollbar-thumb:hover {
	background: #fff; // 鼠标移入滑块颜色
}

.tooltip__tip::-webkit-scrollbar-track {
	border-radius: 3px; // 轨道圆角
	background-color: #888 // 轨道颜色 ;
}
</style>
  • el-tooltip是否禁用原理:获取内容盒子宽度和盒子内容宽度,比较两个值来控制是否禁用 el-tooltip.
  • enterEvents函数:
    • 鼠标移入时触发该函数,在期间设置了参数isShowTooltip控制el-tooltip组件是否禁用;
    • e.target.getBoundingClientRect().width获取内容盒子的具体宽度
  • getElementTextWidth函数:
    • 返回一个盒子内容的宽度;
    • 使用构造函数new Range,性能更高一点;小伙伴们也可以通过创建一个标签来获取宽度也可以得到盒子内容的宽度;

2.3 el-table.vue完整代码

html 复制代码
<template>
	<div>
		<template>
			<el-table border :data="tableData" style="width: 100%">
				<el-table-column align="center" prop="date" label="日期" width="180">
				</el-table-column>
				<el-table-column align="center" prop="name" label="姓名" width="180">
				</el-table-column>
				<el-table-column align="center" prop="address" label="地址">
					<template slot-scope="scope">
						<tooltip :message="scope.row.address"></tooltip>
					</template>
				</el-table-column>
			</el-table>
		</template>
	</div>
</template>
<script>
import tooltip from "@/components/BMW/tableTooltip/tooltip.vue"
export default {
	data() {
		return {
			tableData: [
				{
					date: '2023-08-10',
					name: '王小虎',
					address: '上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄'
				},
				{
					date: '2023-08-10',
					name: '王小虎',
					address: '上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n--------上海市普陀区金沙江路 1518 弄\n--------上海市普陀区金沙江路 1518 弄\n-----  上海市普陀区金沙江路 1518 弄\n-----上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n-----上海市普陀区金沙江路 1518 弄\n-----上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄'
				},
				{
					date: '2023-08-10',
					name: '王小虎',
					address: '上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n'
				},
				{
					date: '2023-08-10',
					name: '王小虎',
					address: '上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄\n  上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄上海市普陀区金沙江路 1518 弄,上海市普陀区金沙江路 1518 弄\n上海市普陀区金沙江路 1518 '
				},
			]
		}
	},
	components: {
		tooltip
	},
}
</script>
<style lang="less" scoped>
</style>

效果截图

  • 效果一

  • 效果二

  • 效果三

写在最后

如果有所帮助,希望能够点赞收藏哦,非常感谢!!!

相关推荐
大橙子额6 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
LYFlied7 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
B站_计算机毕业设计之家8 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
xjt_09019 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农9 小时前
Vue 2.3
前端·javascript·vue.js
跳动的梦想家h10 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring
Mr Xu_11 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
一 乐12 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
科技D人生12 小时前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design12 小时前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven