html2json.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. function e(e) {
  2. for (var t = {}, r = e.split(","), s = 0; s < r.length; s++) t[r[s]] = !0;
  3. return t;
  4. }
  5. function t(e) {
  6. return e.replace(/<\?xml.*\?>\n/, "").replace(/<.*!doctype.*\>\n/, "").replace(/<.*!DOCTYPE.*\>\n/, "");
  7. }
  8. function r(e) {
  9. return e.replace(/\r?\n+/g, "").replace(/<!--.*?-->/gi, "").replace(/\/\*.*?\*\//gi, "").replace(/[ ]+</gi, "<");
  10. }
  11. function s(e) {
  12. var t = [];
  13. if (0 == n.length || !i) return (d = {}).node = "text", d.text = e, s = [ d ];
  14. e = e.replace(/\[([^\[\]]+)\]/g, ":$1:");
  15. for (var r = new RegExp("[:]"), s = e.split(r), a = 0; a < s.length; a++) {
  16. var l = s[a], d = {};
  17. i[l] ? (d.node = "element", d.tag = "emoji", d.text = i[l], d.baseSrc = o) : (d.node = "text",
  18. d.text = l), t.push(d);
  19. }
  20. return t;
  21. }
  22. var a = "https", n = "", o = "", i = {}, l = require("./wxDiscode.js"), d = require("./htmlparser.js"), c = (e("area,base,basefont,br,col,frame,hr,img.vue,input,link,meta,param,embed,command,keygen,source,track,wbr"),
  23. e("br,a,code,address,article,applet,aside,audio,blockquote,button,canvas,center,dd,del,dir,div,dl,dt,fieldset,figcaption,figure,footer,form,frameset,h1,h2,h3,h4,h5,h6,header,hgroup,hr,iframe,ins,isindex,li,map,menu,noframes,noscript,object,ol,output,p,pre,section,script,table,tbody,td,tfoot,th,thead,tr,ul,video")), u = e("abbr,acronym,applet,b,basefont,bdo,big,button,cite,del,dfn,em,font,i,iframe,img.vue,input,ins,kbd,label,map,object,q,s,samp,script,select,small,span,strike,strong,sub,sup,textarea,tt,u,var"), p = e("colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr");
  24. e("checked,compact,declare,defer,disabled,ismap,multiple,nohref,noresize,noshade,nowrap,readonly,selected"),
  25. e("wxxxcode-style,script,style,view,scroll-view,block");
  26. module.exports = {
  27. html2json: function(e, n) {
  28. e = r(e = t(e)), e = l.strDiscode(e);
  29. var o = [], i = {
  30. node: n,
  31. nodes: [],
  32. images: [],
  33. imageUrls: []
  34. }, g = 0;
  35. return d(e, {
  36. start: function(e, t, r) {
  37. var s = {
  38. node: "element",
  39. tag: e
  40. };
  41. if (0 === o.length ? (s.index = g.toString(), g += 1) : (void 0 === (x = o[0]).nodes && (x.nodes = []),
  42. s.index = x.index + "." + x.nodes.length), c[e] ? s.tagType = "block" : u[e] ? s.tagType = "inline" : p[e] && (s.tagType = "closeSelf"),
  43. 0 !== t.length && (s.attr = t.reduce(function(e, t) {
  44. var r = t.name, a = t.value;
  45. return "class" == r && (s.classStr = a), "style" == r && (s.styleStr = a), a.match(/ /) && (a = a.split(" ")),
  46. e[r] ? Array.isArray(e[r]) ? e[r].push(a) : e[r] = [ e[r], a ] : e[r] = a, e;
  47. }, {})), "img" === s.tag) {
  48. s.imgIndex = i.images.length;
  49. var d = s.attr.src;
  50. "" == d[0] && d.splice(0, 1), d = l.urlToHttpUrl(d, a), s.attr.src = d, s.from = n,
  51. i.images.push(s), i.imageUrls.push(d);
  52. }
  53. if ("font" === s.tag) {
  54. var m = [ "x-small", "small", "medium", "large", "x-large", "xx-large", "-webkit-xxx-large" ], f = {
  55. color: "color",
  56. face: "font-family",
  57. size: "font-size"
  58. };
  59. s.attr.style || (s.attr.style = []), s.styleStr || (s.styleStr = "");
  60. for (var h in f) if (s.attr[h]) {
  61. var v = "size" === h ? m[s.attr[h] - 1] : s.attr[h];
  62. s.attr.style.push(f[h]), s.attr.style.push(v), s.styleStr += f[h] + ": " + v + ";";
  63. }
  64. }
  65. if ("source" === s.tag && (i.source = s.attr.src), r) {
  66. var x = o[0] || i;
  67. void 0 === x.nodes && (x.nodes = []), x.nodes.push(s);
  68. } else o.unshift(s);
  69. },
  70. end: function(e) {
  71. var t = o.shift();
  72. if (t.tag !== e && console.error("invalid state: mismatch end tag"), "video" === t.tag && i.source && (t.attr.src = i.source,
  73. delete i.source), 0 === o.length) i.nodes.push(t); else {
  74. var r = o[0];
  75. void 0 === r.nodes && (r.nodes = []), r.nodes.push(t);
  76. }
  77. },
  78. chars: function(e) {
  79. var t = {
  80. node: "text",
  81. text: e,
  82. textArray: s(e)
  83. };
  84. if (0 === o.length) t.index = g.toString(), g += 1, i.nodes.push(t); else {
  85. var r = o[0];
  86. void 0 === r.nodes && (r.nodes = []), t.index = r.index + "." + r.nodes.length,
  87. r.nodes.push(t);
  88. }
  89. },
  90. comment: function(e) {}
  91. }), i;
  92. },
  93. emojisInit: function() {
  94. var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : "", t = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "/wxParse/emojis/", r = arguments[2];
  95. n = e, o = t, i = r;
  96. }
  97. };