Nokogiri解析HTML时,如何避免在结果中包含DOCTYPE声明?
- 内容介绍
- 文章标签
- 相关推荐
本文共计230个文字,预计阅读时间需要1分钟。
参考英文解决方案,以下是对内容的简化
Prevent Nokogiri from adding DOCTYPE tags when parsing HTML. I'm trying to use Nokogiri to generate HTML documents, e.g., for similar purposes: _content=Nokogiri::HTML::Builder.new do |doc|
我正在尝试使用Nokogiri生成部分HTML文档,例如类似的东西:
html_content = Nokogiri::HTML::Builder.new() do |doc| # producing document here, redacted for brevity end.to_html
这样做效果很好,除了一点点捕获:数据稍后将被分派到远程Drupal驱动的服务器并作为页面的一部分呈现,因此不应包含初始的<!DOCTYPE html ...>宣言.
我如何说服Nokogiri不要生产DOCTYPE标签?或者Nokogiri的HTML构建器是错误的方法吗?
提前致谢.
要实现这一点,您可以使用 document fragments和Builder.with方法,如下所示:
require 'nokogiri' include Nokogiri fragment = HTML.fragment('') HTML::Builder.with(fragment) do |f| f.div('foo') end fragment.to_html # => <div>foo</div>
本文共计230个文字,预计阅读时间需要1分钟。
参考英文解决方案,以下是对内容的简化
Prevent Nokogiri from adding DOCTYPE tags when parsing HTML. I'm trying to use Nokogiri to generate HTML documents, e.g., for similar purposes: _content=Nokogiri::HTML::Builder.new do |doc|
我正在尝试使用Nokogiri生成部分HTML文档,例如类似的东西:
html_content = Nokogiri::HTML::Builder.new() do |doc| # producing document here, redacted for brevity end.to_html
这样做效果很好,除了一点点捕获:数据稍后将被分派到远程Drupal驱动的服务器并作为页面的一部分呈现,因此不应包含初始的<!DOCTYPE html ...>宣言.
我如何说服Nokogiri不要生产DOCTYPE标签?或者Nokogiri的HTML构建器是错误的方法吗?
提前致谢.
要实现这一点,您可以使用 document fragments和Builder.with方法,如下所示:
require 'nokogiri' include Nokogiri fragment = HTML.fragment('') HTML::Builder.with(fragment) do |f| f.div('foo') end fragment.to_html # => <div>foo</div>

