首页 > 其他分享 >el-table中的formatter 对列的值进行处理

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

时间:2023-05-19 15:35:33浏览次数:35  
标签:el return name label sex address table formatter row


-后台返回的table数据不符合前端展示,

下面是人员统计表:

el-table中的formatter 对列的值进行处理_代码实现


这样显然是不符合要求的。下面通过elementUI中的table提供了formatter这个属性来对传入的数据进行用户自定义的格式化。

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


目的达到了,直接上代码:

<!--
 * @Descripttion: el-table中的formatter 对列的值进行处理
 * @version: 
 * @Author: zhangfan
 * @email: [email protected]
 * @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: [email protected]
 * @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遍历不生效啊,有点懵逼。希望有知道的大神赐教。


标签:el,return,name,label,sex,address,table,formatter,row
From: https://blog.51cto.com/u_16120408/6312746

相关文章

  • Thymeleaf
    Thymeleaf视图模板技术JavaWeb教程目录|代码重工(gitee.io)6.thymeleaf的部分标签1)使用步骤:添加jar,新建ViewBaseServlet(有两个方法),配置两个<context-param>:view-prefix,view-suffix2)部分标签:<th:if>,<th:unless>,<th:each>,<th:text>7、Thym......
  • EL表达式
    EL表达式1、什么是El表达式,他有什么作用?EL表达式的全称是:ExpressionLanguage。是表达式语言El表达式的作用是:El表达式主要是替代jsp页面中的表达式脚本在jsp页面中进行数据的输出。因为EL表达式在输出数据是,要比jsp的表达式脚本简洁得很多。<body><%request......
  • elementUI实现el-table分页多选功能,解决点击分页之后还可以选中
    <template><div><el-dialogtitle="批量下载推广码":visible.sync="dialogVisibleDownCodeAll"width="900px":before-close="close"><divclass="container"......
  • Excel的开发工具中模块等含义
    如图:      ......
  • DCC32命令行方式编译delphi工程源码
    本文链接地址:http://blog.csdn.net/sushengmiyan/article/details/10284879作者:苏生米沿 一、首先找到这个可执行文件,熟悉delphi的人应该很容易就找到,打开你安装delphi的目录,如我的路径C:\ProgramFiles\Delphi_2007\bin\DCC32.EXE二、拷贝一份出来,我将其放在了我的测试目录下......
  • python使用exchangelib读取、保存exchange邮件
    importosfromdatetimeimportdatetimeimportpytzfromexchangelibimportCredentials,Account,Configuration,DELEGATE,Q,FileAttachmentdefreceived_exchange_message():"""接收exchange邮件,保存邮件到本地:return:""......
  • Shell常用命令
    Shell常用命令shell字符!:执行历史命令!!:执行上一条命令$:变量中取内容符+-*/%:对应数学运算加减乘除取余数&:后台执行;:分号可以在shell中一行执行多个命令,命令之......
  • elementui 表单验证
    ————————————————版权声明:本文为CSDN博主「橙-极纪元」的原创文章,遵循CC4.0BY-SA版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/cplvfx/article/details/125329481介绍Form组件提供了表单验证的功能,只需要通过rules属性传入......
  • STI比赛任务一:【智能问答baseline】
    比赛简介百度搜索首届技术创新挑战赛:赛道一答案抽取STI比赛任务一:【比赛数据分析与长尾发现】STI比赛任务一:【NLP常见优化算法和上分Trick】STI比赛任务一:【智能问答baseline】任务定义本赛题任务是:给定一个用户搜索问题集合Q,基于每个搜索问题q,给定搜索引擎检索得到的网页文档集合......
  • ExtJs GridPanel 自定义汇总
    {text:'订单金额',dataIndex:'amount',renderer:function(value){returnExt.util.Format.number(value,'0.00');},summaryType:function(records){varamount=0;varlength=records.length;for(var......