Nokogiri解析HTML时,如何避免在结果中包含DOCTYPE声明?

2026-04-11 16:151阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计230个文字,预计阅读时间需要1分钟。

Nokogiri解析HTML时,如何避免在结果中包含DOCTYPE声明?

参考英文解决方案,以下是对内容的简化

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时,如何避免在结果中包含DOCTYPE声明?

参见英文答案 > How to prevent Nokogiri from adding <DOCTYPE> tags?2个
我正在尝试使用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分钟。

Nokogiri解析HTML时,如何避免在结果中包含DOCTYPE声明?

参考英文解决方案,以下是对内容的简化

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时,如何避免在结果中包含DOCTYPE声明?

参见英文答案 > How to prevent Nokogiri from adding <DOCTYPE> tags?2个
我正在尝试使用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>