render_html.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. function render_html(name = '') {
  2. var num = 0;
  3. while(1) {
  4. num += 1;
  5. if(document.getElementById(name + '_' + String(num))) {
  6. data = document.getElementById(name + '_' + String(num)).innerHTML;
  7. var src_list = ['www.youtube.com', 'www.google.com', 'play-tv.kakao.com'];
  8. var t_data = [
  9. 'b', 'i', 's', 'del', 'strong', 'bold', 'em', 'sub', 'sup',
  10. 'div', 'span',
  11. 'a',
  12. 'iframe'
  13. ];
  14. for(var key in t_data) {
  15. patt = new RegExp(
  16. '<' + t_data[key] + '( (?:(?:(?!>).)+))?>((?:(?!<\/' + t_data[key] + '>).)*)<\/' + t_data[key] + '>',
  17. 'ig'
  18. );
  19. data = data.replace(patt, function(full, in_data, in_data_2) {
  20. if(['b', 'i', 's', 'del', 'strong', 'bold', 'em', 'sub', 'sup'].includes(t_data[key])) {
  21. return '<' + t_data[key] + '>' + in_data_2 + '</' + t_data[key] + '>'
  22. } else if(t_data[key] === 'div' || t_data[key] === 'span') {
  23. var style_data = in_data.match(/ style=['"]([^'"]*)['"]/);
  24. if(style_data) {
  25. style_data = style_data[1].replace(/position/ig, '');
  26. } else {
  27. style_data = '';
  28. }
  29. return '<' + t_data[key] + ' style="' + style_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  30. } else if(t_data[key] === 'a') {
  31. var link_data = in_data.match(/ href=['"]([^'"]*)['"]/);
  32. if(link_data) {
  33. link_data = link_data[1].replace(/^javascript:/ig, '');
  34. } else {
  35. link_data = '';
  36. }
  37. return '<' + t_data[key] + ' id="out_link" href="' + link_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  38. } else if(t_data[key] === 'iframe') {
  39. var src_data = in_data.match(/ src=['"]([^'"]*)['"]/);
  40. if(src_data) {
  41. src_data = src_data[1];
  42. var src_check = src_data.match(/^http(?:s)?:\/\/([^/]+)/);
  43. if(src_check) {
  44. if(!src_list.includes(src_check[1])) {
  45. src_data = '';
  46. }
  47. } else {
  48. src_data = '';
  49. }
  50. } else {
  51. src_data = '';
  52. }
  53. var width_data = in_data.match(/ width=['"]([^'"]*)['"]/);
  54. if(width_data) {
  55. width_data = width_data[1];
  56. } else {
  57. width_data = '';
  58. }
  59. var height_data = in_data.match(/ height=['"]([^'"]*)['"]/);
  60. if(height_data) {
  61. height_data = height_data[1];
  62. } else {
  63. height_data = '';
  64. }
  65. return '<' + t_data[key] + ' src="' + src_data + '" width="' + width_data + '" height="' + height_data + '" allowfullscreen frameborder="0">' + in_data_2 + '</' + t_data[key] + '>';
  66. } else {
  67. var src_data = in_data.match(/ src=['"]([^'"]*)['"]/);
  68. if(src_data) {
  69. src_data = src_data[1];
  70. } else {
  71. src_data = '';
  72. }
  73. var width_data = in_data.match(/ width=['"]([^'"]*)['"]/);
  74. if(width_data) {
  75. width_data = width_data[1];
  76. } else {
  77. width_data = '';
  78. }
  79. var height_data = in_data.match(/ height=['"]([^'"]*)['"]/);
  80. if(height_data) {
  81. height_data = height_data[1];
  82. } else {
  83. height_data = '';
  84. }
  85. return '<' + t_data[key] + ' controls src="' + src_data + '" width="' + width_data + '" height="' + height_data + '">' + in_data_2 + '</' + t_data[key] + '>';
  86. }
  87. });
  88. }
  89. document.getElementById(name + '_' + String(num)).innerHTML = data;
  90. } else {
  91. break;
  92. }
  93. }
  94. }