我有这段代码:
n = Nokogiri::HTML::DocumentFragment.parse("<a href='{{var_name}}'>click</a>")
当我n.to_html
时,我得到{{ }}
转义:
"<a href=\"%7B%7Bvar_name%7D%7D\">click</a>"
我想避免这种情况,因为我需要使用模板引擎解析它。
我如何告诉Nokogiri不要编码&#34; href&#34;内容?
答案 0 :(得分:5)
我认为不可能告诉Nokogiri 不编码HTML中的参数内的文本值。它是遵循规则的解析器,但这并不意味着我们必须接受它的输出:
require 'nokogiri'
REGEX_HASH = {
'%7B' => '{',
'%7D' => '}'
}
REGEX = /(?:#{ Regexp.union(REGEX_HASH.keys).source })/
# => /(?:%7B|%7D)/
doc = Nokogiri::HTML::DocumentFragment.parse("<a href='{{var_name}}'>click</a>")
doc.to_html
# => "<a href=\"%7B%7Bvar_name%7D%7D\">click</a>"
fixed_html = doc.to_html.gsub(REGEX, REGEX_HASH)
# => "<a href=\"{{var_name}}\">click</a>"
但是,如果XHTML或XML输出可以接受,那么你可以大大简化:
doc = Nokogiri::HTML::DocumentFragment.parse("<a href='{{var_name}}'>click</a>")
doc.to_html # => "<a href=\"%7B%7Bvar_name%7D%7D\">click</a>"
doc.to_xhtml # => "<a href=\"{{var_name}}\">click</a>"
doc.to_xml # => "<a href=\"{{var_name}}\">click</a>"