vue elementUI 标签中使用方法

需求

最近vue项目中使用elementUI的table组件时,后端返回的表格数据不适合修改,编辑罗辑会直接拿去使用,但是后端返回的数据多为id,或者状态(0,1,2...)。对于用户来说不友好,希望在不改变数据的情况小将id或者状态显示正确的数据。

解决方法

通过在表格标签中使用方法,将对应的id与状态显示为用户需要的内容。

代码

html

javascript 复制代码
<el-table ref="table" :data="tableData" border stripe>
	<el-table-column type="selection" width="55" fixed="left"></el-table-column>
	<el-table-column v-for="item in tableTitleList" :key="item.key" :prop="item.key" :label="item.title" show-overflow-tooltip min-width="200">
		<template slot-scope="scope">
			<span v-if="scope.column.property === 'flag'">
                {{ setFlag(scope.row.flag) }}
            </span>
            <span v-else-if="scope.column.property === 'iscall'">
            	{{ setIsCall(scope.row.iscall) }}
            </span>
			<span v-else>{{ scope.row[scope.column.property] }}</span>
		</template>
	</el-table-column>
	<el-table-column label="操作" fixed="right" min-width="230">
		<template slot-scope="scope">
			<el-button class="icon-style" icon="el-icon-view" size="mini" @click="onDetails(scope.row)"></el-button>
			<el-button type="warning" class="icon-style" icon="el-icon-edit" size="mini" @click="onEdit(scope.row)"></el-button>
			<el-button type="danger" class="icon-style" icon="el-icon-delete" size="mini" @click="onDetails(scope.row)"></el-button>
		</template>
	</el-table-column>
</el-table>

js

javascript 复制代码
import api from './api'
export default {
  data() {
    return {
    	loading: false,
    	tableData: [],
    	tableTitleList: []
    }
  },
  created() {
    this.init()
  },
  methods: {
  	// 初始化
    init() {
		api.init().then(res => {
          if (res.code === 2000) {
          	this.tableData = res.data
            // 其他操作
            ...
            this.$nextTick(() => {
              this.loading = false
            })
          }
        }).catch(() => {
          this.loading = false
        })
      })
    },
    // 数据处理
    setFlag(str) {
      // 参数为字符串('1,2,3'),需要转为数组后,根据数据字段查询对应的值
      const flag = str.split(',')
      const flagList = flag.map(ever => {
        return this.getDictData('label', ever) // 查询数据字段的方法,返回值为对应的名称
      })
      return flagList.join(' | ') // 返回结果('张三 | 李四 | 张龙')
    },
    setIsCall(val) {
      // 参数为0 或 1
      if (val === 0 || val === '0') {
        return '未拨打'
      } else {
        return '已拨打'
      }
    },
  }
}
相关推荐
秃了也弱了。14 分钟前
Chrome谷歌浏览器插件ModHeader,修改请求头,开发神器
前端·chrome
乆夨(jiuze)34 分钟前
记录H5内嵌到flutter App的一个问题,引发后面使用fastClick,引发后面input输入框单击无效问题。。。
前端·javascript·vue.js
忧郁的蛋~1 小时前
HTML表格导出为Excel文件的实现方案
前端·html·excel
小彭努力中1 小时前
141.在 Vue 3 中使用 OpenLayers Link 交互:把地图中心点 / 缩放级别 / 旋转角度实时写进 URL,并同步解析显示
前端·javascript·vue.js·交互
然我1 小时前
别再只用 base64!HTML5 的 Blob 才是二进制处理的王者,面试常考
前端·面试·html
NanLing1 小时前
【纯前端推理】纯端侧 AI 对象检测:用浏览器就能跑的深度学习模型
前端
呆呆的心1 小时前
前端必学:从盒模型到定位,一篇搞定页面布局核心 🧩
前端·css
小飞悟1 小时前
前端高手才知道的秘密:Blob 居然这么强大!
前端·javascript·html
小old弟1 小时前
用Sass循环实现炫彩文字跑马灯效果
前端
code_YuJun1 小时前
Promise 基础使用
前端·javascript·promise