el-table中的formatter 对列的值进行处理

本文介绍如何利用ElementUI的table组件中的formatter属性,对后台返回的原始数据进行格式化处理,以达到更佳的前端展示效果。通过具体实例展示了如何将数字代码转换为人性化的文本描述,如性别和地址的格式化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

-后台返回的table数据不符合前端展示,
下面是人员统计表:
在这里插入图片描述
这样显然是不符合要求的。下面通过elementUI中的table提供了formatter这个属性来对传入的数据进行用户自定义的格式化。
在这里插入图片描述
目的达到了,直接上代码:

<!--
 * @Descripttion: el-table中的formatter 对列的值进行处理
 * @version: 
 * @Author: zhangfan
 * @email: 2207044692@qq.com
 * @Date: 2020-07-03 09:10:28
 * @LastEditors: zhangfan
 * @LastEditTime: 2020-07-22 15:27:11
--> 

 <template>
  <div class="tableBox">
    <el-table :data="tableData" style="width: 100%" :row-class-name="tableRowClassName">
      <el-table-column prop="name" label="姓名" width="180"></el-table-column>
      <el-table-column prop="sex" label="性別" width="180" :formatter="formatSex"></el-table-column>
      <el-table-column prop="address" label="出生地" :formatter="formatAddress"></el-table-column>
    </el-table>
  </div>
</template>
<script>
export default {
  data() {
    return {
      tableData: [
        {
          name: "王小虎",
          address: "027",
          sex: 1
        },
        {
          name: "王二狗",
          address: "0851",
          sex: 1
        },
        {
          name: "王小丫",
          address: "024",
          sex: 0
        },
        {
          name: "王小翠",
          address: "0451",
          sex: 0
        }
      ]
    };
  },
  methods: {
    /**
     * @description: 格式化性別
     */
    formatSex(row, column) {
      switch (row.sex) {
        case 1:
          return "男";
          break;
        case 0:
          return "女";
          break;
        default:
          return "未知";
      }
    },
    /**
     * @description: 格式化出生地
     */
    formatAddress(row, column) {
      switch (row.address) {
        case "027":
          return "湖北武汉";
          break;
        case "0851":
          return "贵州贵阳";
          break;
        case "024":
          return "辽宁沈阳";
          break;
        case "0451":
          return "黑龙江哈尔滨";
          break;
        default:
          return "未知";
      }
    }
  }
};
</script>

<style  scoped lang="less">
</style>

效果是达到了,但是代码实现的方式,明显不是我辣条小哥哥的风范。必须优化优化。

<!--
 * @Descripttion: el-table中的formatter 对列的值进行处理
 * @version: 
 * @Author: zhangfan
 * @email: 2207044692@qq.com
 * @Date: 2020-07-03 09:10:28
 * @LastEditors: zhangfan
 * @LastEditTime: 2020-07-22 16:00:31
--> 

 <template>
  <div class="tableBox">
    <el-table :data="tableData" style="width: 100%">
      <el-table-column prop="name" label="姓名" width="180"></el-table-column>
      <el-table-column prop="sex" label="性別" width="180" :formatter="formatSex"></el-table-column>
      <el-table-column prop="address" label="出生地" :formatter="formatAddress"></el-table-column>
    </el-table>
  </div>
</template>
<script>
export default {
  data() {
    return {
      tableData: [
        {
          name: "王小虎",
          address: "027",
          sex: 1
        },
        {
          name: "王二狗",
          address: "0851",
          sex: 1
        },
        {
          name: "王小丫",
          address: "024",
          sex: 0
        },
        {
          name: "王小翠",
          address: "0451",
          sex: 0
        }
      ],
      sexArray: [
        {
          name: 1,
          label: "男"
        },
        {
          name: 0,
          label: "女"
        }
      ],
      addressArray: [
        {
          name: "027",
          label: "湖北武汉"
        },
        {
          name: "0851",
          label: "贵州贵阳"
        },
        {
          name: "024",
          label: "辽宁沈阳"
        },
        {
          name: "0451",
          label: "黑龙江哈尔滨"
        },
        {
          name: "024",
          label: "辽宁沈阳"
        }
      ]
    };
  },
  methods: {
    /**
     * @description: 格式化性別
     */
    formatSex(row, column) {
      for (var i = 0; i < this.sexArray.length; i++) {
        if (this.sexArray[i].name == row.sex) {
          return this.sexArray[i].label;
        }
      }
    },
    /**
     * @description: 格式化出生地
     */
    formatAddress(row, column) {
      for (var i = 0; i < this.addressArray.length; i++) {
        if (this.addressArray[i].name == row.address) {
          return this.addressArray[i].label;
        }
      }
    }
  }
};
</script>

<style  scoped lang="less">
</style>

这样写才是我的风格吗,但是这个地方为什么用foreach遍历不生效啊,有点懵逼。希望有知道的大神赐教。

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值