Class: Nokogiri::HTML4::DocumentFragment
- Inherits:
-
XML::DocumentFragment
- Object
- XML::Node
- XML::DocumentFragment
- Nokogiri::HTML4::DocumentFragment
- Defined in:
- lib/nokogiri/html4/document_fragment.rb
Overview
Direct Known Subclasses
Constant Summary
Constants inherited from XML::Node
XML::Node::ATTRIBUTE_DECL, XML::Node::ATTRIBUTE_NODE, XML::Node::CDATA_SECTION_NODE, XML::Node::COMMENT_NODE, XML::Node::DOCB_DOCUMENT_NODE, XML::Node::DOCUMENT_FRAG_NODE, XML::Node::DOCUMENT_NODE, XML::Node::DOCUMENT_TYPE_NODE, XML::Node::DTD_NODE, XML::Node::ELEMENT_DECL, XML::Node::ELEMENT_NODE, XML::Node::ENTITY_DECL, XML::Node::ENTITY_NODE, XML::Node::ENTITY_REF_NODE, XML::Node::HTML_DOCUMENT_NODE, XML::Node::NAMESPACE_DECL, XML::Node::NOTATION_NODE, XML::Node::PI_NODE, XML::Node::TEXT_NODE, XML::Node::XINCLUDE_END, XML::Node::XINCLUDE_START
Constants included from XML::Searchable
XML::Searchable::LOOKS_LIKE_XPATH
Class Method Summary collapse
-
.parse(tags, encoding = nil) ⇒ Object
Create a Nokogiri::XML::DocumentFragment from
tags
, usingencoding
.
Instance Method Summary collapse
-
#initialize(document, tags = nil, ctx = nil) ⇒ DocumentFragment
constructor
A new instance of DocumentFragment.
Methods inherited from XML::DocumentFragment
#css, #dup, #errors, #errors=, #fragment, #name, new, #search, #to_html, #to_s, #to_xhtml, #to_xml
Methods inherited from XML::Node
#<<, #<=>, #==, #>, #[], #[]=, #accept, #add_child, #add_class, #add_namespace_definition, #add_next_sibling, #add_previous_sibling, #after, #ancestors, #append_class, #attribute, #attribute_nodes, #attribute_with_ns, #attributes, #before, #blank?, #canonicalize, #cdata?, #child, #children, #children=, #classes, #comment?, #content, #content=, #create_external_subset, #create_internal_subset, #css_path, #decorate!, #default_namespace=, #description, #do_xinclude, #document, #document?, #dup, #each, #element?, #element_children, #encode_special_chars, #external_subset, #first_element_child, #fragment, #fragment?, #html?, #inner_html, #inner_html=, #internal_subset, #key?, #keys, #kwattr_add, #kwattr_append, #kwattr_remove, #kwattr_values, #lang, #lang=, #last_element_child, #line, #line=, #matches?, #namespace, #namespace=, #namespace_definitions, #namespace_scopes, #namespaced_key?, #namespaces, #native_content=, new, #next_element, #next_sibling, #node_name, #node_name=, #node_type, #parent, #parent=, #parse, #path, #pointer_id, #prepend_child, #previous_element, #previous_sibling, #processing_instruction?, #read_only?, #remove_attribute, #remove_class, #replace, #serialize, #swap, #text?, #to_html, #to_s, #to_xhtml, #to_xml, #traverse, #unlink, #value?, #values, #wrap, #write_html_to, #write_to, #write_xhtml_to, #write_xml_to, #xml?
Methods included from XML::Searchable
#at, #at_css, #at_xpath, #css, #search, #xpath
Methods included from XML::PP::Node
Methods included from Nokogiri::HTML5::Node
#fragment, #inner_html, #write_to
Constructor Details
#initialize(document, tags = nil, ctx = nil) ⇒ DocumentFragment
Returns a new instance of DocumentFragment.
26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/nokogiri/html4/document_fragment.rb', line 26 def initialize(document, = nil, ctx = nil) return self unless if ctx preexisting_errors = document.errors.dup node_set = ctx.parse("<div>#{}</div>") node_set.first.children.each { |child| child.parent = self } unless node_set.empty? self.errors = document.errors - preexisting_errors else # This is a horrible hack, but I don't care path = if /^\s*?<body/i.match?() "/html/body" else "/html/body/node()" end temp_doc = HTML4::Document.parse("<html><body>#{}", nil, document.encoding) temp_doc.xpath(path).each { |child| child.parent = self } self.errors = temp_doc.errors end children end |
Class Method Details
.parse(tags, encoding = nil) ⇒ Object
Create a Nokogiri::XML::DocumentFragment from tags
, using encoding
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
# File 'lib/nokogiri/html4/document_fragment.rb', line 7 def self.parse(, encoding = nil) doc = HTML4::Document.new encoding ||= if .respond_to?(:encoding) encoding = .encoding if encoding == ::Encoding::ASCII_8BIT 'UTF-8' else encoding.name end else 'UTF-8' end doc.encoding = encoding new(doc, ) end |