国际化处理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

相关文章

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

springboot+vue项目怎么解决跨域问题详解

《springboot+vue项目怎么解决跨域问题详解》:本文主要介绍springboot+vue项目怎么解决跨域问题的相关资料,包括前端代理、后端全局配置CORS、注解配置和Nginx反向代理,... 目录1. 前端代理(开发环境推荐)2. 后端全局配置 CORS(生产环境推荐)3. 后端注解配置(按接口

Python中CSV文件处理全攻略

《Python中CSV文件处理全攻略》在数据处理和存储领域,CSV格式凭借其简单高效的特性,成为了电子表格和数据库中常用的文件格式,Python的csv模块为操作CSV文件提供了强大的支持,本文将深入... 目录一、CSV 格式简介二、csv模块核心内容(一)模块函数(二)模块类(三)模块常量(四)模块异常

QT6中绘制UI的两种方法详解与示例代码

《QT6中绘制UI的两种方法详解与示例代码》Qt6提供了两种主要的UI绘制技术:​​QML(QtMeta-ObjectLanguage)​​和​​C++Widgets​​,这两种技术各有优势,适用于不... 目录一、QML 技术详解1.1 QML 简介1.2 QML 的核心概念1.3 QML 示例:简单按钮

Python实现获取带合并单元格的表格数据

《Python实现获取带合并单元格的表格数据》由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,所以本文我们就来聊聊如何使用Python实现获取带合并单元格的表格数据吧... 由于在日常运维中经常出现一些合并单元格的表格,如果要获取数据比较麻烦,现将将封装成类,并通过调用list_exc

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

详解如何在SpringBoot控制器中处理用户数据

《详解如何在SpringBoot控制器中处理用户数据》在SpringBoot应用开发中,控制器(Controller)扮演着至关重要的角色,它负责接收用户请求、处理数据并返回响应,本文将深入浅出地讲解... 目录一、获取请求参数1.1 获取查询参数1.2 获取路径参数二、处理表单提交2.1 处理表单数据三、

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

在 PyQt 加载 UI 三种常见方法

《在PyQt加载UI三种常见方法》在PyQt中,加载UI文件通常指的是使用QtDesigner设计的.ui文件,并将其转换为Python代码,以便在PyQt应用程序中使用,这篇文章给大家介绍在... 目录方法一:使用 uic 模块动态加载 (不推荐用于大型项目)方法二:将 UI 文件编译为 python 模

Nginx 访问 /root/下 403 Forbidden问题解决

《Nginx访问/root/下403Forbidden问题解决》在使用Nginx作为Web服务器时,可能会遇到403Forbidden错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录解决 Nginx 访问 /root/test/1.html 403 Forbidden 问题问题复现Ng