js實現【JSON格式化】

JSON格式化步驟

  1. 識別出有效JSON
  2. 去掉全部空格縮進換行
  3. 識別{},:進行格式化:
    • {},換行
    • :後面加空格
    • 注意要點:JSON的鍵值中,也可能在字符串中存在{},:。例如:{"a{},:b": 0}。格式化時須要先排除這部份內容。

JSON去除空格 + 過濾無效JSON

/* param1 JSONstr 未格式化的JSON字符串 return 去【類空格字符】後的JSON字符串 */
function JSONTrim(JSONstr) {
    try {
        JSONstr = JSONstr.replace(/'/g, '"');
        JSONstr = JSON.stringify(JSON.parse(JSONstr));
    } catch (error) {
        // 轉換失敗錯誤提示
        console.error('json數據格式有誤...');
        console.error(error);
        JSONstr = null;
    }
    return JSONstr;
}
複製代碼

JSON格式化

/* param1 JSONstr 未格式化的JSON字符串 return 格式化後的JSON字符串 */
function JSONFormat(JSONstr) {
  JSONstr = JSONTrim(JSONstr); // 初步格式化json

  let re = new RegExp('\\{|\\}|,|:', 'g'); // 匹配格式化後的json中的{},:
  let exec = null;
  let InvalidFs = 0;
  let InvalidBs = 0;
  while(exec = re.exec(JSONstr)) { // 找{},:
    let frontToCurrent = exec.input.substr(0, exec.index + 1); // 匹配開頭到當前匹配字符之間的字符串
    if (frontToCurrent.replace(/\\"/g, "").replace(/[^"]/g, "").length%2 != 0) { // 測試當前字符到開頭"的數量,爲雙數則被斷定爲目標對象
      if(exec[0] === '{') InvalidFs++;
      else if(exec[0] === '}') InvalidBs++;
      continue; // 不是目標對象,手動跳過
    }
    let keyTimesF = frontToCurrent.replace(/[^\{]/g, '').length - InvalidFs; // 找出當前匹配字符以前全部{的個數
    let keyTimesB = frontToCurrent.replace(/[^\}]/g, '').length - InvalidBs; // 找出當前匹配字符以前全部}的個數
    let indentationTimes = keyTimesF - keyTimesB; // 根據{個數計算縮進

    if (exec[0] === '{') {
      JSONstr = JSONstr.slice(0,exec.index + 1) + '\n' + '\t'.repeat(indentationTimes) + JSONstr.slice(exec.index + 1); // 將縮進加入字符串
    } else if(exec[0] === '}') {
      JSONstr = JSONstr.slice(0,exec.index) + '\n' + '\t'.repeat(indentationTimes) + JSONstr.slice(exec.index) // 將縮進加入字符串
      re.exec(JSONstr); // 在查找目標前面插入字符串會回退本次查找,因此手動跳過本次查找
    } else  if(exec[0] === ',') {
      JSONstr = JSONstr.slice(0,exec.index + 1) + '\n' + '\t'.repeat(indentationTimes) + JSONstr.slice(exec.index + 1)
    } else if (exec[0] === ':') {
      JSONstr = JSONstr.slice(0,exec.index + 1) + ' ' + JSONstr.slice(exec.index + 1)
    } else {
      console.log(`匹配到了來路不明的${exec[0]}`)
    }
  }
  return JSONstr;
}
複製代碼

示例字符串

能夠將如下字符串打亂格式進行測試,包含了比較複雜的狀況javascript

{
	"uu{{{{{{::}},}uc\\\"u": "kkkk",
	"oooooo": {
		
	},
	"pp2": {
		"662": {
			"****": 9
		},
		"k": 88888
	},
	"c___9": true,
	"*": 3
}
複製代碼

歡迎指教

這是我JSON格式化的思路,但願你們能夠多多驗證,指出問題。java

相關文章
相關標籤/搜索