vue vxe-table表格标题根据内容宽度自动换行

本文介绍了如何在Vue的vxe-table组件中实现表格标题自动换行和根据列宽改变自适应内容。通过修改表头样式,添加列宽改变回调函数,结合Vuex存储原始标题,实现了标题的动态调整。文章还提供了一个截取字符串的辅助方法,确保标题在不同宽度下展示合适的内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文首发于个人站点 vue vxe-table表格标题根据内容宽度自动换行
笔者个人站点 秋码记录

1、首先修改 vxe-table 表头样式

.vTable-table .vxe-table .vxe-table--header .vxe-header--row  .vxe-header--column  .vxe-cell--title {
	white-space:pre-wrap;
	word-wrap: break-word;
}

2、添加改变列宽度的回调方法

<vxeTable ref="table"
	<!--省略表格属性 以及方法  这些不是本文的重点-->				
@resizable-change="resizableChange"></vxeTable>
            /**
             * 在改变表格宽度时 表头内容自适应宽度
             * @param column {object} 当前移动的列对象
             */
            resizableChange({column }){
				
				let orgColumn = this.$store.state.autoFilter.columnTitleObj
				orgColumn.forEach(item => {
					try{
						if(item.prop == column.property){
							this.$store.commit("SET_ORG_TITLE", item['orgTitle'])
							throw new Error('退出循环!');
						}

					}catch(e){
						console.log(e)
					}
				})


				let orgTitle = this.$store.state.autoFilter.orgTitle

				let l = orgTitle.length //column.title.length
				let f = 16 //每一个字大小,实际上是每一个字的比例值,大概会比字体大小差很少大一点,
				let labelWidth = f * l //字大小乘个数即长度 ,注意不要加px像素,这里minWidth只是一个比例值,不是真正

				let minWidth = column['minWidth']

				let subLen = ~~(2 * (Number(column['resizeWidth']) - 30 )) / f

				let lineCount = ~~((Number(column['resizeWidth']) - 30 ) / f)
				let showTextNum = 2 * lineCount

				// 最小宽度 120 扣除 30  一行 90 显示两行 180
				if(l > showTextNum){
					column.title = this.subString(orgTitle,10,true)
					
				}else{
					column.title = this.subString(orgTitle,subLen,false)
					
				}

			},

			/**
			 * 截取中英文字符
			 * @param str {string} 原始字符
			 * @param len {number} 需截取的字符长度
			 * @param hasDot {boolean} 是否需要省略号
			 * @returns {string} 返回截取后的新字符
			 */
			subString(str, len, hasDot) {
				var newLength = 0;
				var newStr = "";
				var chineseRegex = "/[^\x00-\xff]/g";
				var singleChar = "";
				var strLength = str.replace(chineseRegex, "**").length;
				for (var i = 0; i < strLength; i++) {
					singleChar = str.charAt(i).toString();
					if (singleChar.match(chineseRegex) != null) {
						newLength += 2;
					}
					else {
						newLength++;
					}
					if (newLength > len) {
						break;
					}
					newStr += singleChar;
				}


				if (hasDot && strLength > len) {
					newStr += "...";
				}
				return newStr;
			},

3、使用vuex保留原始的表头标题

export default {
	state: {
		columnTitleObj: [], //列表头标题
		orgTitle: '', //原表头标题
	},
	mutations:{
		SET_COLUMN_TITLE(state,item){
			state.columnTitleObj = item
		},
		SET_ORG_TITLE(state,item){
			state.orgTitle = item
		},
	}

4、最终实现效果如下

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

甄齐才

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

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

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

打赏作者

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

抵扣说明:

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

余额充值