javascript - innerHTML如何去除缩进
问题描述
已解决各位好:
欲在html中用template标签里面写Markdown,再用js对Markdown进行处理转换成html,局部dom结构如下:
<p class='content'> <template type='markdown'> Welcome ==== My name is Hung </template></p><script type='text/javascript'> document.addEventListener(’DOMContentLoaded’ ,function (event){ var $templates = document.querySelectorAll(’template[type='markdown']’) $templates.forEach(function ($template){ console.log(marked($template.innerHTML)); }) })</script>
但是因为template标签有缩进,导致了marked把内容当做段落代码处理:
请问又没法办法清除这些缩进,但是又不影响正常缩进的方式,或者不用template标签的其他方式
问题解答
回答1:给你一个思路,统计每一行前面的空白符,得到一个最小值,再按这个最小值清除
补上代码
document.querySelectorAll(’template[type='markdown']’).forEach($template => { var lines = $template.innerHTML.split(/rn|n/) var trimLen = lines.reduce((minLen, line) => { var len = (/S/.exec(line) || {index: 0}).index if (len < minLen) { return len } return minLen }, Infinity) if (trimLen > 0) { lines = lines.map(line => line.slice(trimLen)) } console.log(marked(lines.join(’n’)))})回答2:
document.querySelectorAll(’template[type='markdown']’).forEach(($template) => { let lines = $template.innerHTML.split(’n’) let linesNum = lines.length if (linesNum > 0){ !!/^s*$/.test(lines[0]) && lines.shift() !!/^s*$/.test(lines[linesNum-1]) && lines.pop() } let markdown = lines.map(line => line.substring(Math.min(...lines.map(line => line.match(/^s*/)[0].length)))).join(’n’) $template.parentElement.innerHTML = marked(markdown)})
相关文章:
1. python - pyspider爬pdf爬了一小段时间后就不动了2. 如何合并两张具有相同结构的mysql表3. javascript - Ajax加载Json时,移动端页面向左上角缩小一截儿,加载完成后才正常显示,这该如何解决?4. python运行后没有任何反馈要怎么排查5. javascript - h5 video层级太高导致浮在div上面,如何解决?6. linux - Ubuntu下编译Vim8(+python)无数次编译失败7. css - 请问B站顶部的模糊半透明导航条是怎么实现的呢?8. python中怎么对列表以区间进行统计?9. mysql - 记得以前在哪里看过一个估算时间的网站10. mysql ER_BAD_DB_ERROR: Unknown database ’test’
