Elementel-table的formatter和scope template不能同时存在问题解决办法

一、需求:公司项目中一个需要展示文件信息table表,考虑到文件大小字段展示值后面要加上单位(B,KB,MB,GB),文件大小字段后端没有进行单位转换,准备在前端拿到后转换并且加上单位。

二·、问题:很容易想到了el-table组件formatter属性:

我在el-table-column里面添加属性,进行打印测试,一直不生效,后来经过排查发现事template中插槽作用域导致的,也就是formatter作用于单个字段(即一个el-table-column)就是下面这种:

而我的项目用的是scope template插槽,就是下面这种结构:

这样就产生了问题。

三、解决办法:使用slot,自定义 formatter。上代码:

1.html:

<div v-else-if="item.prop === 'file_size'"> <span v-html="formatter(scope.row.file_size, item.prop)"></span> </div>

方法中第一个参数为对象值(即value),第二个参数为对象字段(即key)

2.js:

methods: { formatter(row, value) { if (value == "file_size") { if (row < 1024) { return row + "B" } else if (row < 1024*1024) { return (Number(row) / 1024).toFixed(3) + "KB" } else if (row < 1024*1024*1024) { return (Number(row) / 1024 / 1024).toFixed(3) + "MB" } else { return (Number(row) / 1024 / 1024 / 1024).toFixed(3) + "GB" } } }, }

四、最后展示效果:

参考资料:

ishell1021
moranrun
Element组件官方文档

到此这篇关于Element el-table的formatter和scope template不能同时存在问题解决办法的文章就介绍到这了,更多相关el-table 的 formatter 和 scope template内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!

推荐阅读

    table设置列宽|table 列宽

    table设置列宽|table 列宽,,table 列宽直接给每一列的第一行设置宽度就可以了,下边的默认与第一行的相同,如果需要修改,在单独设置就可以,下边

    table边框设置|table边框设置成双线

    table边框设置|table边框设置成双线,,1. table边框设置成双线点选表格,菜单--格式--边框和底纹,在线型中往下拉,你会看到双线,选择后确定就行

    lua的弱表(weak table)简介

    lua的弱表(weak table)简介,字符串,对象, 变量和值的区别变量是值的载体,变量消失,值却不一定消失objectTables, functions,

    antimalware service executable怎么关【关闭方法】

    antimalware service executable怎么关【关闭方法】,单击,设置,选择,下拉菜单,威胁,图标,  最近不少用户在使用电脑的时候发现自己的电脑非常

    索尼平板tablet s怎么刷机

    索尼平板tablet s怎么刷机,索尼,平板,索尼平板tablet s怎么刷机卡刷刷机方法:一、备份个人数据资料到电脑端或其他设备或云空间。二、将要

    Win10电脑开机提示“no bootable device”解决方法

    Win10电脑开机提示“no bootable device”解决方法,开机,设置,硬盘,提示,模式,解决方法,  近期,有win10用户碰到电脑无法开机,开机之后提示&ldq

    Json和Lua table互转的Lua模块

    Json和Lua table互转的Lua模块,分词,字符串,先分词,再解析,少写了语法检查module( "json_to_lua", package.seeall )--##################

    C#取得DataTable最大值、最小值

    C#取得DataTable最大值、最小值,最大值,最小值,C#取得DataTable最大值、最小值int max=int.Parse((dtItemsAll.Compute("Max(CPITEMS_SOR

    Lua中打印Table的方法|lua table成员

    Lua中打印Table的方法|lua table成员,遍历,你的, print东西如果很多 会很消耗效率 不需要的时候把前面三行的return打开就可以了这个方法

    Win10蓝屏终止代码WHEA_UNCORRECTABLE_ERROR的解决方法

    Win10蓝屏终止代码WHEA_UNCORRECTABLE_ERROR的解决方法,蓝屏,方法,系统,主板,设置,解决方法,  我们在使用windows操作系统的时候,比较常见的故

    Hypertable简介

    Hypertable简介,数据,主要用于,2006年Google公布了自己的BigTable论文,作为Google继GFS和MapReduce两项创新之后的又一项创新,其在设计用来