// ==UserScript==
// @license MIT
// @name JSON Viewer
// @namespace http://tampermonkey.net/
// @version 0.4.8
// @note v0.4.8 代码优化
// @note v0.4.7 增加对JSONP的判断,代码优化
// @note v0.4.6 增加复制按钮,JSON脑图CSS样式细节优化,JSON脑图增加收起/展开子节点按钮
// @note v0.4.5 在json-viewer-updated原基础上进行了一些修改,主要有CSS样式修改,新增折叠/展开全部功能,新增JSON脑图功能,脑图节点点击显示调用路径
// @description 格式化显示JSON使数据看起来更加漂亮,支持折叠/展开格式化后的数据,支持JSON脑图让调用层级看着更清晰,支持复制JSON脑图节点路径
// @author Feny
// @match *://*/*
// @grant GM_addStyle
// @grant GM_getResourceText
// @grant GM_setClipboard
// @icon 
// @require https://code.jquery.com/jquery-3.4.1.min.js
// @require https://unpkg.com/layer-src@3.5.1/dist/layer.js
// @require https://unpkg.com/jsmind@0.8.5/es6/jsmind.js
// @resource swalStyle https://unpkg.com/jsmind@0.8.5/style/jsmind.css
// @resource layerStyle https://unpkg.com/layer-src@3.5.1/dist/theme/default/layer.css
// @downloadURL none
// ==/UserScript==
/*随机字符串*/
function randomString(e) {
var e = e || 32,
t = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678",
a = t.length,
n = "";
for (i = 0; i < e; i++){
n += t.charAt(Math.floor(Math.random() * a));
}
return n
}
/*检查是否是图片链接*/
function isImg(pathImg) {
var regexp = /^(http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?\/([\w#!:.?+=&%@!\-\/])*\.(gif|jpg|jpeg|png|GIF|JPG|PNG)([\w#!:.?+=&%@!\-\/])?/;
return regexp.test(pathImg);
}
/** 检验内容是否是json格式的内容*/
function isJSON(str) {
if (typeof str == 'string') {
try {
var obj = JSON.parse(str);
if(typeof obj == 'object' && obj ){
console.log("is json")
return true;
}else{
console.log("is not json")
return false;
}
} catch(e) {
console.log("is not json", e)
return false;
}
}
}
// jquery.json-viewer 插件 开始
// 解决和原网页jquery版本冲突
var jq = jQuery.noConflict(true);
(function(jq){
/**
* 检查 arg 是否为至少包含 1 个元素的数组或至少包含 1 个键的字典
*/
function isCollapsable(arg) {
return arg instanceof Object && Object.keys(arg).length > 0;
}
/**
* 检查字符串是否为URL
*/
function isUrl(string) {
var regexp = /^(ftp|http|https):\/\/(\w+:{0,1}\w*@)?(\S+)(:[0-9]+)?(\/|\/([\w#!:.?+=&%@!\-\/]))?/;
return regexp.test(string);
}
/**
* 将 JSON 对象转换为 HTML 表示形式
* @return string
*/
function json2html(json) {
var html = '';
if (typeof json === 'string') {
/* Escape tags */
json = json.replace(/&/g, '&').replace(//g, '>');
if (isUrl(json)){
html += `"${json}"`;
}
else{
html += `"${json}"`;
}
}
else if (typeof json === 'number') {
html += `${json}`;
}
else if (typeof json === 'boolean') {
html += `${json}`;
}
else if (json === null) {
html += 'null';
}
else if (json instanceof Array) {
if (json.length > 0) {
html += '[
';
for (var i = 0; i < json.length; ++i) {
html += '
';
/* Add toggle button if item is collapsable */
if (isCollapsable(json[i])) {
html += '';
}
html += json2html(json[i]);
/* Add comma if item is not last */
if (i < json.length - 1) {
html += ',';
}
html += '
';
}
html += ']';
}
else {
html += '[]';
}
}
else if (typeof json === 'object') {
var key_count = Object.keys(json).length;
if (key_count > 0) {
html += '{
';
for (var key in json) {
if (json.hasOwnProperty(key)) {
html += '
';
/* Add toggle button if item is collapsable */
if (isCollapsable(json[key])) {
html += '';
}
html += `"${key}": ${json2html(json[key])}`;
/* Add comma if item is not last */
if (--key_count > 0){
html += ',';
}
html += '
';
}
}
html += '
}';
}
else {
html += '{}';
}
}
return html;
}
jq.fn.jsonViewer = function(json, jsonpFunctionName) {
return this.each(function() {
/* Transform to HTML */
var html = json2html(json);
/** is JSONP */
if(jsonpFunctionName !== undefined && jsonpFunctionName !== null){
html = `