Description
The functx:is-node-among-descendants-deep-equal function returns a boolean value indicating whether or not a node has the same contents as a node in a sequence, or one of the descendants of a node in the sequence. It determines whether the nodes have the same content using the built-in fn:deep-equal function. If $node or $seq is the empty sequence, it returns false.
For a similar function based on the identity of a node rather than its contents, see functx:is-node-among-descendants.
Arguments and Return TypeName | Type | Description |
$node |
node()? |
the node to test |
$seq |
node()* |
the sequence of nodes to search |
return value |
xs:boolean |
XSLT Function DeclarationSee XQuery definition. | <xsl:function name="functx:is-node-among-descendants-deep-equal" as="xs:boolean"
xmlns:functx="http://www.functx.com">
<xsl:param name="node" as="node()?"/>
<xsl:param name="seq" as="node()*"/>
<xsl:sequence select="
some $nodeInSeq in $seq/descendant-or-self::*/(.|@*)
satisfies deep-equal($nodeInSeq,$node)
"/>
</xsl:function>
|
Examples<xsl:variable name="in-xml" as="item()*"> | | <authors>
<author>
<fName>Kate</fName>
<lName>Jones</lName>
</author>
<author>
<fName>John</fName>
<lName>Doe</lName>
</author>
</authors> |
| </xsl:variable> | <xsl:variable name="anAuthor" as="item()*"> | | <author>
<fName>John</fName>
<lName>Doe</lName>
</author> |
| </xsl:variable> | <xsl:variable name="anotherAuthor" as="item()*"> | | <author>
<lName>Doe</lName>
<fName>John</fName>
</author> |
| </xsl:variable> |
XPath Example | Results |
---|
functx:is-node-among-descendants-deep-equal(
$in-xml/author[1],$in-xml) |
true |
functx:is-node-among-descendants-deep-equal(
$anAuthor,$in-xml) |
true |
functx:is-node-among-descendants-deep-equal(
$anotherAuthor,$in-xml) |
false |
functx:is-node-among-descendants-deep-equal(
$anAuthor,$in-xml/author) |
true |
See AlsoHistory |
Recommended Reading:
|