Element el-table的formatter和scope?template不能同時存在問題解決辦法
一、需求:公司項目中一個需要展示文件信息table表,考慮到文件大小字段展示值后面要加上單位(B,KB,MB,GB),文件大小字段后端沒有進行單位轉換,準備在前端拿到后轉換并且加上單位。
二·、問題:很容易想到了el-table組件formatter屬性:

我在el-table-column里面添加屬性,進行打印測試,一直不生效,后來經過排查發(fā)現事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內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用element-ui,el-row中的el-col數據為空頁面布局變亂問題
這篇文章主要介紹了使用element-ui,el-row中的el-col數據為空頁面布局變亂問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
詳解windows下vue-cli及webpack 構建網站(四) 路由vue-router的使用
本篇文章主要介紹了windows下vue-cli及webpack 構建網站(四) 路由vue-router的使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06

