国际化处理Avue或者elment-ui表格的列宽问题

2024-03-01 22:12

本文主要是介绍国际化处理Avue或者elment-ui表格的列宽问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要用于处理国际化多语言,文字长度导致表格宽度变形问题

调用方式如下:

//man.js
import avueUtils from "@/util/avue-utils";
// avue 全局配置
Vue.prototype.$avueUtils = avueUtils;
//elment-ui的表格调用<el-table-column prop="time" :label="" width="80":render-header="$avueUtils.columnFit"></el-table-column>//AVUE表格调用,tableOption是配置项,对配置项进行处理,调用:this.$avueUtils.fit,传入this,和配置对象就好了<avue-crudref="crud":page="page":data="tableData":permission="permissionList":option="tableOption"/>tableOption() {return this.$avueUtils.fit(this,{border: true,menu: this.$store.state.user.userInfo.userType === '1',index: true,height: '100%',indexLabel: this.generateTitle("序号"),stripe: true,menuAlign: "center",align: "center",}

JS封装

/*** 计算列宽度** @param column* @param language*/
function calculateColumnWidth(column, language) {if (!column.label) {return column.minWidth;}// 不同语言不同的字宽度let fontSize;switch (language) {case "zh-CN":fontSize = 17;break;case "en":fontSize = 11;break;case "vi":fontSize = 11;break;}let width = fontSize * (column.label.length + 2);// 如果开启过滤if (column.filters) {width += 12;}// 如果开启排序if (column.sortable) {width += 24;}return width;
}/*** 更新列宽度** @param column* @param language*/
function updateColumnWidth(column, language) {// 记录原始宽度if (column.width && !column._originalWidth) {column._originalWidth = column.width;}column.minWidth = calculateColumnWidth(column, language);// 原设定宽度和计算出的最小列宽度取其高if (column._originalWidth && column.minWidth && column._originalWidth < column.minWidth) {column.width = column.minWidth;} else if (column._originalWidth) {column.width = column._originalWidth;}
}export default {/*** 包装AVue配置,注入全局属性** @param page  当前页面vue实例* @param options AVue配置* @returns {*} 表格配置*/fit(page, options) {let language = page.$store.getters.language;// 序号options.index = true;options.indexLabel = page.generateTitle("序号");// 表格样式options.stripe = true;options.border = true;options.menuAlign = "center";options.align = "center";// 按钮options.refreshBtn = false;options.columnBtn = false;// 空数据options.emptyText = page.generateTitle("暂无数据");// 弹框options.dialogWidth = "80%";// 不同国际化语言特殊处理switch (page.$store.getters.language) {case "zh-CN":options.indexWidth = "70px";break;case "en":options.indexWidth = "120px";break;case "vi":options.indexWidth = "100px";break;}// 列处理if (options.column) {for (let col of options.column) {updateColumnWidth(col, language);col.minWidth = calculateColumnWidth(col, language);}}return options;},/*** 列宽度自适应* 适用于 elementUI 的render-header** @param h* @param data* @returns {*}*/columnFit(h, data) {let page = data._self;let language = page.$store.getters.language;updateColumnWidth(data.column, language);return h("div", {class: "table-head", style: {width: "100%"}}, [data.column.label]);}}

这篇关于国际化处理Avue或者elment-ui表格的列宽问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/763991

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja