fix(接口测试): 修复case保存不正常的json数据后,不显示的缺陷
--bug=1033211 --user=王孝刚 【接口测试】github#27710,接口CASE中请求体Json数据如果有红叉,保存后重新打开该CASE json格式请求体数据不显示 https://www.tapd.cn/55049933/s/1444855
This commit is contained in:
parent
e1452d380e
commit
53353d3ed7
|
@ -1,4 +1,9 @@
|
|||
export function formatJson (json) {
|
||||
export function formatJson(json) {
|
||||
try {
|
||||
JSON.parse(json);
|
||||
} catch (e) {
|
||||
return json;
|
||||
}
|
||||
let i = 0,
|
||||
il = 0,
|
||||
tab = " ",
|
||||
|
@ -10,133 +15,150 @@ export function formatJson (json) {
|
|||
for (i = 0, il = json.length; i < il; i += 1) {
|
||||
currentChar = json.charAt(i);
|
||||
switch (currentChar) {
|
||||
case '{':
|
||||
if (i != 0 && json.charAt(i - 1) === '$') {
|
||||
case "{":
|
||||
if (i != 0 && json.charAt(i - 1) === "$") {
|
||||
newJson += currentChar;
|
||||
flag = true;
|
||||
} else if (!inString) {
|
||||
newJson += currentChar + "\n" + repeat(tab, indentLevel + 1);
|
||||
indentLevel += 1
|
||||
indentLevel += 1;
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case '[':
|
||||
case "[":
|
||||
if (!inString) {
|
||||
newJson += currentChar + "\n" + repeat(tab, indentLevel + 1);
|
||||
indentLevel += 1
|
||||
indentLevel += 1;
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case '}':
|
||||
case "}":
|
||||
if (flag) {
|
||||
newJson += currentChar;
|
||||
flag = false;
|
||||
} else if (!inString) {
|
||||
indentLevel -= 1;
|
||||
newJson += "\n" + repeat(tab, indentLevel) + currentChar
|
||||
newJson += "\n" + repeat(tab, indentLevel) + currentChar;
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case ']':
|
||||
case "]":
|
||||
if (!inString) {
|
||||
indentLevel -= 1;
|
||||
newJson += "\n" + repeat(tab, indentLevel) + currentChar
|
||||
newJson += "\n" + repeat(tab, indentLevel) + currentChar;
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case ',':
|
||||
case ",":
|
||||
if (!inString) {
|
||||
newJson += ",\n" + repeat(tab, indentLevel)
|
||||
newJson += ",\n" + repeat(tab, indentLevel);
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case ':':
|
||||
case ":":
|
||||
if (!inString) {
|
||||
newJson += ": "
|
||||
newJson += ": ";
|
||||
} else {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case ' ':
|
||||
case " ":
|
||||
case "\n":
|
||||
case "\t":
|
||||
if (inString) {
|
||||
newJson += currentChar
|
||||
newJson += currentChar;
|
||||
}
|
||||
break;
|
||||
case '"':
|
||||
if (i > 0 && json.charAt(i - 1) !== '\\') {
|
||||
inString = !inString
|
||||
if (i > 0 && json.charAt(i - 1) !== "\\") {
|
||||
inString = !inString;
|
||||
}
|
||||
newJson += currentChar;
|
||||
break;
|
||||
default:
|
||||
newJson += currentChar;
|
||||
break
|
||||
break;
|
||||
}
|
||||
}
|
||||
return newJson;
|
||||
}
|
||||
|
||||
function repeat(s, count) {
|
||||
return new Array(count + 1).join(s)
|
||||
return new Array(count + 1).join(s);
|
||||
}
|
||||
|
||||
|
||||
|
||||
export function formatXml(text) {
|
||||
//去掉多余的空格
|
||||
text = '\n' + text.replace(/(<\w+)(\s.*?>)/g, function ($0, name, props) {
|
||||
return name + ' ' + props.replace(/\s+(\w+=)/g, " $1");
|
||||
text =
|
||||
"\n" +
|
||||
text.replace(/(<\w+)(\s.*?>)/g, function ($0, name, props) {
|
||||
return name + " " + props.replace(/\s+(\w+=)/g, " $1");
|
||||
});
|
||||
//把注释编码
|
||||
text = text.replace(/<!--(.+?)-->/g, function ($0, text) {
|
||||
var ret = '<!--' + escape(text) + '-->';
|
||||
var ret = "<!--" + escape(text) + "-->";
|
||||
//alert(ret);
|
||||
return ret;
|
||||
});
|
||||
//调整格式
|
||||
var rgx = /\n(<(([^\?]).+?)(?:\s|\s*?>|\s*?(\/)>)(?:.*?(?:(?:(\/)>)|(?:<(\/)\2>)))?)/mg;
|
||||
var rgx =
|
||||
/\n(<(([^\?]).+?)(?:\s|\s*?>|\s*?(\/)>)(?:.*?(?:(?:(\/)>)|(?:<(\/)\2>)))?)/gm;
|
||||
var nodeStack = [];
|
||||
var output = text.replace(rgx, function ($0, all, name, isBegin, isCloseFull1, isCloseFull2, isFull1, isFull2) {
|
||||
var isClosed = (isCloseFull1 == '/') || (isCloseFull2 == '/' ) || (isFull1 == '/') || (isFull2 == '/');
|
||||
var output = text.replace(
|
||||
rgx,
|
||||
function (
|
||||
$0,
|
||||
all,
|
||||
name,
|
||||
isBegin,
|
||||
isCloseFull1,
|
||||
isCloseFull2,
|
||||
isFull1,
|
||||
isFull2
|
||||
) {
|
||||
var isClosed =
|
||||
isCloseFull1 == "/" ||
|
||||
isCloseFull2 == "/" ||
|
||||
isFull1 == "/" ||
|
||||
isFull2 == "/";
|
||||
//alert([all,isClosed].join('='));
|
||||
var prefix = '';
|
||||
if (isBegin == '!') {
|
||||
var prefix = "";
|
||||
if (isBegin == "!") {
|
||||
prefix = getPrefix(nodeStack.length);
|
||||
}
|
||||
else {
|
||||
if (isBegin != '/') {
|
||||
} else {
|
||||
if (isBegin != "/") {
|
||||
prefix = getPrefix(nodeStack.length);
|
||||
if (!isClosed) {
|
||||
nodeStack.push(name);
|
||||
}
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
nodeStack.pop();
|
||||
prefix = getPrefix(nodeStack.length);
|
||||
}
|
||||
}
|
||||
var ret = '\n' + prefix + all;
|
||||
var ret = "\n" + prefix + all;
|
||||
return ret;
|
||||
});
|
||||
}
|
||||
);
|
||||
var prefixSpace = -1;
|
||||
var outputText = output.substring(1);
|
||||
//把注释还原并解码,调格式
|
||||
outputText = outputText.replace(/(\s*)<!--(.+?)-->/g, function ($0, prefix, text) {
|
||||
if (prefix.charAt(0) == '\r')
|
||||
prefix = prefix.substring(1);
|
||||
text = unescape(text).replace(/\r/g, '\n');
|
||||
var ret = '\n' + prefix + '<!--' + text.replace(/^\s*/mg, prefix) + '-->';
|
||||
outputText = outputText.replace(
|
||||
/(\s*)<!--(.+?)-->/g,
|
||||
function ($0, prefix, text) {
|
||||
if (prefix.charAt(0) == "\r") prefix = prefix.substring(1);
|
||||
text = unescape(text).replace(/\r/g, "\n");
|
||||
var ret = "\n" + prefix + "<!--" + text.replace(/^\s*/gm, prefix) + "-->";
|
||||
//alert(ret);
|
||||
return ret;
|
||||
});
|
||||
return outputText.replace(/\s+$/g, '').replace(/\r/g, '\r\n');
|
||||
}
|
||||
);
|
||||
return outputText.replace(/\s+$/g, "").replace(/\r/g, "\r\n");
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -147,11 +169,12 @@ export function formatXml(text) {
|
|||
*/
|
||||
export function formatTime(time, cFormat) {
|
||||
if (arguments.length === 0) return null;
|
||||
if ((time + '').length === 10) {
|
||||
if ((time + "").length === 10) {
|
||||
time = +time * 1000;
|
||||
}
|
||||
let format = cFormat || '{y}-{m}-{d} {h}:{i}:{s}', date;
|
||||
if (typeof time === 'object') {
|
||||
let format = cFormat || "{y}-{m}-{d} {h}:{i}:{s}",
|
||||
date;
|
||||
if (typeof time === "object") {
|
||||
date = time;
|
||||
} else {
|
||||
date = new Date(time);
|
||||
|
@ -163,23 +186,24 @@ export function formatTime(time, cFormat) {
|
|||
h: date.getHours(),
|
||||
i: date.getMinutes(),
|
||||
s: date.getSeconds(),
|
||||
a: date.getDay()
|
||||
a: date.getDay(),
|
||||
};
|
||||
return format.replace(/{([ymdhisa])+}/g, (result, key) => {
|
||||
let value = formatObj[key];
|
||||
if (key === 'a') return ['一', '二', '三', '四', '五', '六', '日'][value - 1];
|
||||
if (key === "a")
|
||||
return ["一", "二", "三", "四", "五", "六", "日"][value - 1];
|
||||
if (result.length > 0 && value < 10) {
|
||||
value = '0' + value;
|
||||
value = "0" + value;
|
||||
}
|
||||
return value || 0;
|
||||
});
|
||||
}
|
||||
|
||||
function getPrefix(prefixIndex) {
|
||||
var span = ' ';
|
||||
var span = " ";
|
||||
var output = [];
|
||||
for (var i = 0; i < prefixIndex; ++i) {
|
||||
output.push(span);
|
||||
}
|
||||
return output.join('');
|
||||
return output.join("");
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue