繁体   English   中英

如何使用JavaScript删除html标签并保留换行符?

[英]How to remove html tags using JavaScript and keep newline?

我想从我的contenteditable div中删除富文本格式,以便从剪贴板粘贴某些内容时仅保留newlinebr标签。

我正在尝试但不起作用http://jsfiddle.net/marco83/zkf5jkqu/

<div id="editableDiv" contentEditable="true" style="min-height: 200px; border: solid 1px #0099FF;"></div>

<input type="button" value="remove" onclick="strip();">

<script>
function strip() {
    var mydiv = document.getElementById("editableDiv");
    var str  = mydiv.innerHTML;
    str = str.replace(/<br>/gi, "\n");
    str = str.replace(/<(?:.|\s)*?>/g, "");
    mydiv.innerHTML = str;
}
</script>

我从此页面复制了文本http://www.jacklmoore.com/autosize/
我知道它没有任何<br>标记文本。 但是我怎么能像Twitter这样呢? 谢谢。

在此处输入图片说明

尝试这个

<script>
    function strip() {
        var mydiv = document.getElementById("editableDiv");
        var str = mydiv.innerHTML;
        mydiv.innerHTML = remove_tags(str);
    }


    function remove_tags(html) {
        html = html.replace(/<br>/g, "$br$");
        html = html.replace(/(?:\r\n|\r|\n)/g, '$br$');
        var tmp = document.createElement("DIV");
        tmp.innerHTML = html;
        html = tmp.textContent || tmp.innerText;
        html = html.replace(/\$br\$/g, "<br>");
        return html;
    }
</script>

这里的例子

所以我正在做的是,用占位符$br$替换<br>\\n以保留它们,然后从字符串中删除所有HTML标记,并用<br>替换$br$

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM