YUI编辑:删除内容中的标签

时间:2009-03-04 18:27:40

标签: javascript ruby-on-rails yui richtextbox yui-editor

我实施了YUI rich text editor,我希望在保存编辑器中的内容后立即删除<html><body>DOCTYPE标记。我知道我之后可以通过解析HTML来做到这一点,但必须有一个更好的解决方案。

现在,当我在YUI编辑器中编辑文本时,会保存它:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd">
<html>
    <body>
        <p>foo</p>
    </body>
</html>

...但我想保存这个:

<p>foo</p>

有什么想法吗?

P.S。:我使用yui_editor plugin for ruby on rails实现了YUI编辑器,但也欢迎YUI编辑器通用答案!

2 个答案:

答案 0 :(得分:1)

与此同时,我通过在提交时解析html来解决问题。是的,我知道,我最初并不是在寻找这个解决方案,但最后我得出结论,这是解决它的最简单方法。我使用R Nokogiri RubyGem来进行解析:

value = Nokogiri::HTML(yui_content).css('body').to_html 
value.gsub!(/<body>/,'') 
value.gsub!(/<\/body>/,'')

答案 1 :(得分:0)

一种解决方案就是这样,它使用正则表达式来捕捉<body&gt;之间的所有内容。和</body>。示例(从YUI编辑器页面修改):

var myEditor = new YAHOO.widget.Editor('msgpost');
myEditor.render();

YAHOO.util.Event.on('somebutton', 'click', function() {
    myEditor.saveHTML();

    //The var html will now have the contents of the textarea
    var html = myEditor.get('element').value, match;

    match = html.match(/<body[^>]*>([\s\S]*?)<\/body>/i);
    html = match ? match[1] : html;
});