vue3表格组件formatter

有时候在网页上显示表格数据时,表格的某些列值只有有限数目(例如,启用/停用),这时候后端常常使用不同的数据值表示不同状态,前端怎么将这些数据值转化为相应的列值呢?

我们可以采用vue3表格组件formatter实现这一点。

例如:

后端返回的数据格式:

java 复制代码
tableData:[
  {
    "id": "1",
    "recCreateTime": "2024-08-01 09:27:47",
    "name": "张三",
    "sex": 0,
    "status":1
  },
  {
    "id": "2",
    "recCreateTime": "2024-08-01 09:28:10",
    "name": "李四",
    "sex": 0,
    "status":0
  },
  {
    "id": "3",
    "recCreateTime": "2024-08-01 09:28:41",
    "name": "王五",
    "sex": 1,
    "status":1
  },
  {
    "id": "4",
    "recCreateTime": "2024-08-01 09:30:03",
    "name": "刘六",
    "sex": 0,
    "status":1
  }
]

前端可以这样处理:

html 复制代码
<el-table :data="tableData" style="width: 100%" :height="screenHeight * 0.8">
	  <el-table-column label="序号" width="50px" align="center">
	    <template slot-scope="scope">
	      {{ scope.$index + 1 }}
	    </template>
	  </el-table-column>
	  <el-table-column :label="$t('用户名')" prop="name" align="center"/>
	  <el-table-column :label="$t('创建日期')" prop="recCreateTime" align="center"/>
	  <el-table-column :label="$t('性别')" prop="sex" align="center" :formatter="sextypeFormatter"/>
	  <el-table-column :label="$t('状态')" prop="status" align="center" :formatter="statustypeFormatter"/>
</el-table>

export default {
	methods: {
	    sextypeFormatter: function (row) {
	        if(row.sex == 0){
	          return "男"
	        }
	        else if(row.sex == 1){
	          return "女"
	        }
	    },
	    statustypeFormatter: function (row) {
	        if(row.status == 0){
	          return "未启用"
	        }
	        else{
	          return "已启用"
	        }
	    }
}
相关推荐
呱牛do it3 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 3)
java·vue
MXN_小南学前端7 小时前
watch详解:与computed 对比以及 Vue2 / Vue3 区别
前端·javascript·vue.js
2601_949814698 小时前
Docker部署Spring Boot + Vue项目
vue.js·spring boot·docker
Lkstar10 小时前
逐步搞懂 Vue 的 patchChildren,把 Diff 算法拆给你看
vue.js
呱牛do it11 小时前
企业级门户网站设计与实现:基于SpringBoot + Vue3的全栈解决方案(Day 4)
java·vue
nbsaas-boot12 小时前
100万门店级分货系统架构设计
前端·javascript·vue.js
笋笋~13 小时前
el-tree 拖拽事件隔离:实现句柄独立控制,区域分离
javascript·vue.js·elementui
前端那点事13 小时前
Vue生命周期速查:Vue2+Vue3钩子全解析,新手也能秒懂
前端·vue.js
Aotman_14 小时前
Element UI 表格搜索高亮
前端·javascript·vue.js·ui·elementui
yqcoder15 小时前
[特殊字符] Vue 3 中 Keep-Alive 对生命周期的影响:深度解析
前端·javascript·vue.js