Files
hb_pqs_web/src/views/components/exceedancetable.vue
2025-01-09 19:02:44 +08:00

421 lines
10 KiB
Vue

<template>
<div>
<!-- 过滤筛选: <el-input v-model="search" clearable size="small" style="width: 250px" placeholder="筛选数据"/> -->
<!-- <el-button @click="exportExcel" style="float:right;margin-bottom:10px" size="small" type="primary">导出Excel文件</el-button> -->
<el-table
stripe
:data="tables"
style="width: 100%; margin-bottom: 10px"
row-key="id"
id="rebateSetTable"
border
:height="tableheight + 'px'"
:header-cell-style="{
//background:'#5E95E8',
//color:'#FFFFFF',
height: '25px',
padding: '0px',
}"
header-cell-class-name="table_header"
highlight-current-row
:row-style="{ height: '28px' }"
:cell-style="{ padding: '0px' }"
:default-expand-all="false"
@sort-change="sortchange"
>
<el-table-column align="center" prop="cj" label="序号"></el-table-column>
<el-table-column
prop="name"
:label="typedata"
sortable
width="120"
></el-table-column>
<el-table-column
align="center"
prop="cj"
label="项目/工程/单位/部门"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="zd"
label="电压等级"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="监测点名称"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="干扰源类型"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="监测点对象名称"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="超标天数"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="频率偏差"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="电压偏差"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="电压总畸变率"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="谐波电压含有率"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="谐波电压"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="cs"
label="谐波电流"
sortable
width="170"
></el-table-column>
<el-table-column align="center" label="各次谐波电压含有率" width="120">
<el-table-column
align="center"
prop="sort"
label="3次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="5次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="7次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="1次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="13次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="23次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="25次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="其他次"
sortable
width="100"
></el-table-column>
</el-table-column>
<el-table-column align="center" label="各次谐波电流含量" width="120">
<el-table-column
align="center"
prop="sort"
label="3次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="5次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="7次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="1次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="13次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="23次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="25次"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="其他次"
sortable
width="100"
></el-table-column>
</el-table-column>
<el-table-column
align="center"
prop="sort"
label="间谐波电压含有率"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="三相电压不平衡度"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="负序电流"
sortable
width="170"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="闪变"
sortable
width="100"
></el-table-column>
<el-table-column
align="center"
prop="sort"
label="监测点编号"
sortable
width="170"
></el-table-column>
</el-table>
<pagination
:pageData="pageData"
@changePageNum="changePageNum"
@changePageSize="changePageSize"
></pagination>
</div>
</template>
<script>
import { getheight } from "../../assets/commjs/common";
import pagination from "../components/pagination/index";
import FileSaver from "file-saver";
import XLSX from "xlsx";
import json2csv from "json2csv";
export default {
computed: {
// 实时监听表格
tables: function () {
const search = this.search;
if (search) {
return this.tableData.filter((dataNews) => {
return Object.keys(dataNews).some((key) => {
return String(dataNews[key]).toLowerCase().indexOf(search) > -1;
});
});
}
return this.tableData;
},
},
data() {
return {
search: "",
typedata: "电网拓扑",
tableheight: undefined,
pageData: {
pageNum: 3,
pageSize: 15,
total: 100,
},
tableData: [],
};
},
watch: {
classvalue: function (a, b) {
if (a == 0) {
this.typedata = "电网拓扑";
} else if (a == 1) {
this.typedata = "终端厂家";
} else if (a == 2) {
this.typedata = "电压等级";
} else if (a == 3) {
this.typedata = "干扰源类型";
} else if (a == 4) {
this.typedata = "灿能上报";
}
},
},
props: {
type: Number,
classvalue: undefined,
},
components: {
pagination,
},
created() {},
mounted() {
//this.tableheight = (getheight()*2.02)
},
methods: {
// 判断是否IE浏览器
MyBrowserIsIE() {
let isIE = false;
if (
navigator.userAgent.indexOf("compatible") > -1 &&
navigator.userAgent.indexOf("MSIE") > -1
) {
// ie浏览器
isIE = true;
}
if (navigator.userAgent.indexOf("Trident") > -1) {
// edge 浏览器
isIE = true;
}
return isIE;
},
//创建a标签下载
createDownLoadClick(content, fileName) {
const link = document.createElement("a");
link.href = encodeURI(content);
link.download = fileName;
document.body.appendChild(link);
link.click();
document.body.removeChild(link);
},
exporeCSV(rows) {
try {
const result = json2csv.parse(rows, {
// fields: fields,
excelStrings: true,
});
if (this.MyBrowserIsIE()) {
// IE10以及Edge浏览器
var BOM = "\uFEFF";
// 文件转Blob格式
var csvData = new Blob([BOM + result], { type: "text/csv" });
navigator.msSaveBlob(csvData, `导出数据.csv`);
} else {
let csvContent = "data:text/csv;charset=utf-8,\uFEFF" + result;
// 非ie 浏览器
this.createDownLoadClick(csvContent, `导出数据.csv`);
}
} catch (err) {
alert(err);
}
},
exportExcel() {
/* generate workbook object from table */
let wb = XLSX.utils.table_to_book(
document.querySelector("#rebateSetTable")
);
/* get binary string as output */
let wbout = XLSX.write(wb, {
bookType: "xlsx",
bookSST: true,
type: "array",
});
try {
FileSaver.saveAs(
new Blob([wbout], { type: "application/octet-stream" }),
"数据表.xlsx"
);
} catch (e) {
if (typeof console !== "undefined"){}// console.log(e, wbout);
}
return wbout;
},
changePageNum(data) {
this.pageData.pageNum = data;
alert("父组件当前页" + this.pageData.pageNum);
},
changePageSize(data) {
this.pageData.pageSize = data;
alert("父组件当前条数" + this.pageData.pageSize);
},
sortchange() {},
},
};
</script>
<style lang="scss" scoped>
::v-deep .el-table.el-table--enable-row-hover .el-table__body tr:hover > td {
background: $themeColor-8 !important;
}
</style>