vue-element-admin表格json数据渲染,异常数据一行显示红色

简介: vue-element-admin表格json数据渲染,异常数据一行显示红色

功能:

在json数据里面,patrolState为0 的时候,代表异常,当数据异常的时候,这一行表格的数据都标红。

步骤

1:在views底下新建一个test文件夹

里面新建一个vue文件和一个json文件

备用

2:使用

mock.json

{
    "msg": "查询成功",
    "total": 0,
    "code": 1,
    "data": [
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 12:30:00",
            "leaveTime": "2021-07-16 12:40:00",
            "patrolState": 0,
            "id": 1,
            "name": "ls",
            "deviceId": "0000001",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        },
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 16:52:00",
            "leaveTime": "2021-07-16 16:52:00",
            "patrolState": 1,
            "id": 2,
            "name": "zs",
            "deviceId": "0000002",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        },
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 16:58:00",
            "leaveTime": "2021-07-16 16:58:00",
            "patrolState": 0,
            "id": 3,
            "name": "zs",
            "deviceId": "0000003",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        },
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 16:59:00",
            "leaveTime": "2021-07-16 16:59:00",
            "patrolState": 1,
            "id": 4,
            "name": "zs",
            "deviceId": "0000004",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        },
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 16:59:00",
            "leaveTime": "2021-07-16 16:59:00",
            "patrolState": 1,
            "id": 4,
            "name": "zs",
            "deviceId": "0000004",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        },
        {
            "stationMac": "TH:23:IJ:12:DF",
            "arriveTime": "2021-07-16 16:59:00",
            "leaveTime": "2021-07-16 16:59:00",
            "patrolState": 1,
            "id": 4,
            "name": "zs",
            "deviceId": "0000004",
            "sex": 1,
            "authority": 0,
            "organId": 0,
            "organName": "A部门",
            "stationName": "2号基站",
            "address": "官大会展红心",
            "organIds": null,
            "isPagination": false,
            "page": 1,
            "rows": 1
        }
    ]
}

test.vue

<template>
  <div class="app-container">
    <el-table
      :data="pvData.slice((currentPage - 1) * pagesize, currentPage * pagesize)"
      border
      fit
      highlight-current-row
     :row-class-name="tableRowClassName"
    >
      <el-table-column  prop="deviceId" label="终端编号"></el-table-column>
      <el-table-column  prop="name" label="姓名"></el-table-column>
      <el-table-column    :formatter="formatSex" prop="sex" label="性别"></el-table-column>
      <el-table-column prop="organName" label="部门"></el-table-column>
      <el-table-column prop="arriveTime" label="到达时间"></el-table-column>
      <el-table-column prop="leaveTime" label="离开时间"></el-table-column>
      <el-table-column  prop="stationName" label="基站名称"></el-table-column>
      <el-table-column prop="stationMac" label="基站MAC"></el-table-column>
      <el-table-column prop="address" label="基站地址"></el-table-column>
      <el-table-column  prop="patrolState"  :formatter="formatStatus" label="状态"></el-table-column>
    </el-table>
    <el-pagination
      style="margin: 12px 0px"
      background
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="currentPage"
      :page-sizes="[5,10,20, 40]"
      :page-size="pagesize"
      layout="total, sizes, prev, pager, next, jumper"
      :total="pvData.length"
    >
    </el-pagination>
  </div>
</template>
<script>
export default {
  data() {
    return {
      // 分页
      currentPage: 1, //初始页
      pagesize: 5, //    每页的数据
      pvData: [],
    };
  },
  created() {
    //查询管理表格接口
    this.getQuerycheckList();
  },
  methods: {
    // 初始页currentPage、初始每页数据数pagesize和数据data
    handleSizeChange: function (size) {
      this.pagesize = size;
      console.log(this.pagesize); //每页下拉显示数据
    },
    handleCurrentChange: function (currentPage) {
      this.currentPage = currentPage;
      console.log(this.currentPage); //点击第几页
    },
    // 表格接口定义
    getQuerycheckList() {
     this.dataLoading = true;
     import('./mock').then((res) => {      
        this.pvData = res.data;
        this.dataLoading = false;
      });
    },
    //判断巡更数据是否异常
     tableRowClassName({row}) {
      return row.patrolState == 0? 'errorStatus' : '' 
    },
     //格式化状态
    formatStatus(row, column) {
      return row.patrolState === 1 ? "正常" : "异常";
    },
     //格式化性别
    formatSex(row, column) {
      return row.sex === 1 ? "男" : "女";
    },
  },
};
</script>
<style lang="scss">
  .el-table tr.el-table__row.errorStatus{
    color: red;
  }
</style>

相关文章
|
14天前
|
数据采集 JSON 数据处理
抓取和分析JSON数据:使用Python构建数据处理管道
在大数据时代,电商网站如亚马逊、京东等成为数据采集的重要来源。本文介绍如何使用Python结合代理IP、多线程等技术,高效、隐秘地抓取并处理电商网站的JSON数据。通过爬虫代理服务,模拟真实用户行为,提升抓取效率和稳定性。示例代码展示了如何抓取亚马逊商品信息并进行解析。
抓取和分析JSON数据:使用Python构建数据处理管道
|
3天前
|
JSON 缓存 前端开发
PHP如何高效地处理JSON数据:从编码到解码
在现代Web开发中,JSON已成为数据交换的标准格式。本文探讨了PHP如何高效处理JSON数据,包括编码和解码的过程。通过简化数据结构、使用优化选项、缓存机制及合理设置解码参数等方法,可以显著提升JSON处理的性能,确保系统快速稳定运行。
|
4天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
21 1
|
4天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
21 1
|
8天前
|
监控 JavaScript 前端开发
Vue 异步渲染
【10月更文挑战第23天】Vue 异步渲染是提高应用性能和用户体验的重要手段。通过理解异步渲染的原理和优化策略,我们可以更好地利用 Vue 的优势,开发出高效、流畅的前端应用。同时,在实际开发中,要注意数据一致性、性能监控和调试等问题,确保应用的稳定性和可靠性。
|
11天前
|
API
vue3知识点:响应式数据的判断
vue3知识点:响应式数据的判断
20 3
|
12天前
|
存储 缓存 JavaScript
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
30 2
|
18天前
|
JSON JavaScript Java
在Java中处理JSON数据:Jackson与Gson库比较
本文介绍了JSON数据交换格式及其在Java中的应用,重点探讨了两个强大的JSON处理库——Jackson和Gson。文章详细讲解了Jackson库的核心功能,包括数据绑定、流式API和树模型,并通过示例演示了如何使用Jackson进行JSON解析和生成。最后,作者分享了一些实用的代码片段和使用技巧,帮助读者更好地理解和应用这些工具。
在Java中处理JSON数据:Jackson与Gson库比较
|
29天前
|
JavaScript
vue3,使用watch监听props中的数据
【10月更文挑战第3天】
800 2
|
29天前
|
JSON JavaScript API
(API接口系列)商品详情数据封装接口json数据格式分析
在成长的路上,我们都是同行者。这篇关于商品详情API接口的文章,希望能帮助到您。期待与您继续分享更多API接口的知识,请记得关注Anzexi58哦!