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 "已启用"
	        }
	    }
}
相关推荐
JING小白1 小时前
Day 1 重学Vue:响应式系统的“底层逻辑”变更,Vue2旧时代的终结与Vue3新时代的开启
前端·vue.js
OpenTiny社区4 小时前
从零开发 AI 聊天页要两周?试试这款 Vue3 垂直对话组件库 TinyRobot,直接开箱即用
前端·vue.js·github
Cobyte5 小时前
22.Vue Vapor 组件 props 的实现
前端·javascript·vue.js
白雾茫茫丶7 小时前
探索 Nuxt.js 全栈能力:用 Better-Auth 打造类型安全的 RBAC 权限系统
前端·vue.js·nuxt.js
向阳而生6607 小时前
文件上传也能玩出花?Vue3 教你优雅实现“选择文件”和“选择文件夹”🚀
vue.js
3630458417 小时前
Signal 带来的架构问题思考
前端·vue.js
古夕1 天前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
Ruihong1 天前
Vue withDefaults 转 React:VuReact 怎么处理?
vue.js·react.js·面试
稀土熊猫君1 天前
一个人能做出什么开源项目?
vue.js·后端·开源
DarkLONGLOVE2 天前
快速上手 Pinia!Vue3 极简状态管理使用教程
javascript·vue.js