我实施了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编辑器通用答案!
答案 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;
});