NAME
XML::Chain::Selector - selector for traversing the XML::Chain
SYNOPSIS
my $user = xc('user', xmlns => 'testns')
->auto_indent(1)
->c('name')->t('Johnny Thinker')->up
->c('username')->t('jt')->up
->c('bio')
->c('div', xmlns => 'http://www.w3.org/1999/xhtml')
->c('h1')->t('about')->up
->c('p')->t('...')->up
->up
->c('greeting')->t('Hey')
->root;
say $user->as_string;
Will print:
<user xmlns="testns">
<name>Johnny Thinker</name>
<username>jt</username>
<bio>
<div xmlns="http://www.w3.org/1999/xhtml">
<h1>about</h1>
<p>...</p>
</div>
<greeting>Hey</greeting>
</bio>
</user>
DESCRIPTION
CHAINED METHODS
c, append_and_current
Appends new element to current elements and changes context to them. New element is defined in parameters:
$xc->c('i', class => 'icon-download icon-white')
# <i class="icon-download icon-white"/>
First parameter is name of the element, then followed by optional element attributes.
t, append_text
Appends text to current elements.
xc('span')->t('some')->t(' ')->t('more text')
# <span>some more text</span>
First parameter is name of the element, then followed by optional element attributes.
root
Sets document element as current element.
say xc('p')
->t('this ')
->c('b')
->t('is')->up
->t(' important!')
->root->as_string;
# <p>this <b>is</b> important!</p>
up, parent
Traverse current elements and replace them by their parents.
find
say $xc->find('//p/b[@class="less"]')->text_content;
Look-up elements by xpath and set them as current elements.
children
Set all current elements child nodes as current elements.
first
Set first current elements as current elements.
empty
Removes all child nodes from current elements.
auto_indent
my $simple = xc('div')
->auto_indent(1)
->c('div')->t('in')
->root;
say $simple->as_string;
Will print:
<div>
<div>in</div>
</div>
Turn on/off tidy/auto-indentation of document elements. Default indentation characters are tabs.
Argument can be either true/false scalar or a hashref with indentation options. Currently {chars=
' 'x4} > will set indentation characters to be four spaces.
NOTE Currently works only on element on which as_string()
is called using HTML::Tidy. In the future it is planned to be possible to set indentation on/off also for nested elements. For example not to indent embedded html elements.
WARNING HTML::Tidy has a circular reference and leaks memory when used. Better don't use auto_indent() at in this version in persistent environments.
CHAINED DOCUMENT METHODS
See "CHAINED DOCUMENT METHODS" in XML::Chain.
METHODS
as_string, toString
Returns string representation of current XML elements. Call root before to get a string representing the whole document.
$xc->as_string
$xc->root->as_string
as_xml_libxml
Returns array of current elements as XML::LibXML objects.
text_content
Returns text content of all current XML elements.
count / size
say $xc->find('//b')->count;
Return the number of current elements.
single
my $lxml_el = $xc->find('//b')->first->as_xml_libxml;
Checks is there is exactly one element in current elements and return it as XML::Chain::Element object.
AUTHOR
Jozef Kutej
COPYRIGHT & LICENSE
Copyright 2017 Jozef Kutej, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.