fix(接口测试): sql 查询多表格式化优化
This commit is contained in:
parent
744de357c3
commit
4190eb92fd
|
@ -7,8 +7,8 @@
|
||||||
<el-collapse-transition>
|
<el-collapse-transition>
|
||||||
<el-tabs v-model="activeName" v-show="isActive">
|
<el-tabs v-model="activeName" v-show="isActive">
|
||||||
<el-tab-pane :class="'body-pane'" label="Body" name="body" class="pane">
|
<el-tab-pane :class="'body-pane'" label="Body" name="body" class="pane">
|
||||||
<ms-sql-result-table v-if="isSqlType" :body="response.body"/>
|
<ms-sql-result-table v-if="isSqlType && mode == 'table'" :body="response.body"/>
|
||||||
<ms-code-edit v-if="!isSqlType" :mode="mode" :read-only="true" :data="response.body" :modes="modes" ref="codeEdit"/>
|
<ms-code-edit v-if="mode != 'table'" :mode="mode" :read-only="true" :data="response.body" :modes="modes" ref="codeEdit"/>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
<el-tab-pane label="Headers" name="headers" class="pane">
|
<el-tab-pane label="Headers" name="headers" class="pane">
|
||||||
<pre>{{ response.headers }}</pre>
|
<pre>{{ response.headers }}</pre>
|
||||||
|
@ -21,9 +21,10 @@
|
||||||
<pre>{{response.vars}}</pre>
|
<pre>{{response.vars}}</pre>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
<el-tab-pane v-if="activeName == 'body' && !isSqlType" :disabled="true" name="mode" class="pane assertions">
|
<el-tab-pane v-if="activeName == 'body'" :disabled="true" name="mode" class="pane assertions">
|
||||||
<template v-slot:label>
|
<template v-slot:label>
|
||||||
<ms-dropdown :commands="modes" :default-command="mode" @command="modeChange"/>
|
<ms-dropdown v-if="!isSqlType" :commands="modes" :default-command="mode" @command="modeChange"/>
|
||||||
|
<ms-dropdown v-if="isSqlType" :commands="sqlModes" :default-command="mode" @command="sqlModeChange"/>
|
||||||
</template>
|
</template>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
|
|
||||||
|
@ -59,6 +60,7 @@ export default {
|
||||||
isActive: true,
|
isActive: true,
|
||||||
activeName: "body",
|
activeName: "body",
|
||||||
modes: ['text', 'json', 'xml', 'html'],
|
modes: ['text', 'json', 'xml', 'html'],
|
||||||
|
sqlModes: ['text', 'table'],
|
||||||
mode: BODY_FORMAT.TEXT
|
mode: BODY_FORMAT.TEXT
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -69,6 +71,9 @@ export default {
|
||||||
},
|
},
|
||||||
modeChange(mode) {
|
modeChange(mode) {
|
||||||
this.mode = mode;
|
this.mode = mode;
|
||||||
|
},
|
||||||
|
sqlModeChange(mode) {
|
||||||
|
this.mode = mode;
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
<template>
|
<template>
|
||||||
|
<div>
|
||||||
<el-table
|
<el-table
|
||||||
:data="tableData"
|
v-for="(table, index) in tables"
|
||||||
|
:key="index"
|
||||||
|
:data="table.tableData"
|
||||||
border
|
border
|
||||||
size="mini"
|
size="mini"
|
||||||
highlight-current-row>
|
highlight-current-row>
|
||||||
<el-table-column v-for="(title, index) in titles" :key="index" :label="title" min-width="15%">
|
<el-table-column v-for="(title, index) in table.titles" :key="index" :label="title" min-width="150px">
|
||||||
<template v-slot:default="scope">
|
<template v-slot:default="scope">
|
||||||
<el-popover
|
<el-popover
|
||||||
placement="top"
|
placement="top"
|
||||||
|
@ -17,6 +20,7 @@
|
||||||
</template>
|
</template>
|
||||||
</el-table-column>
|
</el-table-column>
|
||||||
</el-table>
|
</el-table>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -24,7 +28,7 @@
|
||||||
name: "MsSqlResultTable",
|
name: "MsSqlResultTable",
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
tableData: [],
|
tables: [],
|
||||||
titles: []
|
titles: []
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -36,29 +40,71 @@
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
let rowArry = this.body.split("\n");
|
let rowArry = this.body.split("\n");
|
||||||
let title;
|
this.getTableData(rowArry);
|
||||||
|
if (this.tables.length > 1) {
|
||||||
|
for (let i = 0; i < this.tables.length; i++) {
|
||||||
|
if (this.tables[i].titles.length === 1 && i < this.tables.length - 1) {
|
||||||
|
this.tables[i].tableData.splice(this.tables[i].tableData.length - 1, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let lastTable = this.tables[this.tables.length - 1];
|
||||||
|
if (lastTable.titles.length === 1) {
|
||||||
|
if (lastTable.tableData.length > 4) {
|
||||||
|
lastTable.tableData.splice(lastTable.tableData.length - 4, 4);
|
||||||
|
} else {
|
||||||
|
this.tables.splice(this.tables.length - 1, 1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
this.tables.splice(this.tables.length - 1, 1);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
let table = this.tables[0];
|
||||||
|
table.tableData.splice(table.tableData.length - 4, 4);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
getTableData(rowArry) {
|
||||||
|
let titles;
|
||||||
let result = [];
|
let result = [];
|
||||||
for (let i = 0; i < rowArry.length; i++) {
|
for (let i = 0; i < rowArry.length; i++) {
|
||||||
let colArray = rowArry[i].split("\t");
|
let colArray = rowArry[i].split("\t");
|
||||||
if (i === 0) {
|
if (i === 0) {
|
||||||
title = colArray;
|
titles = colArray;
|
||||||
|
} else {
|
||||||
|
if (colArray.length != titles.length) {
|
||||||
|
// 创建新的表
|
||||||
|
if (colArray.length === 1 && colArray[0] === '') {
|
||||||
|
this.getTableData(rowArry.slice(i + 1));
|
||||||
|
} else {
|
||||||
|
this.getTableData(rowArry.slice(i));
|
||||||
|
}
|
||||||
|
break;
|
||||||
} else {
|
} else {
|
||||||
let item = {};
|
let item = {};
|
||||||
for (let j = 0; j < colArray.length; j++) {
|
for (let j = 0; j < colArray.length; j++) {
|
||||||
item[title[j]] = (colArray[j] ? colArray[j] : "");
|
item[titles[j]] = (colArray[j] ? colArray[j] : "");
|
||||||
}
|
}
|
||||||
result.push(item);
|
result.push(item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.titles = title;
|
}
|
||||||
this.tableData = result;
|
|
||||||
this.tableData.splice(this.tableData.length - 3, 3);
|
this.tables.splice(0, 0, {
|
||||||
|
titles: titles,
|
||||||
|
tableData: result
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped>
|
<style scoped>
|
||||||
|
|
||||||
|
.el-table {
|
||||||
|
margin-bottom: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
.el-table >>> .cell {
|
.el-table >>> .cell {
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue