Ben Nadel
On User Experience (UX) Design, JavaScript, ColdFusion, Node.js, Life, and Love.
I am the chief technical officer at InVision App, Inc - a prototyping and collaboration platform for designers, built by designers. I also rock out in JavaScript and ColdFusion 24x7.
Meanwhile on Twitter
Loading latest tweet...
Ben Nadel at Scotch On The Rock (SOTR) 2010 (London) with:

Use XmlParent To Get The Parent Node In An XML Document In ColdFusion

By Ben Nadel on
Tags: ColdFusion

Every now and then, you learn something that seems so obvious that it's completely embarrassing that you didn't know it in the first place. You know, like the first time you realized that it's "intents and purposes", not "intensive purposes," or when you first learned that girls really do make poo. I had a similarly embarrassing moment earlier this week when I learned about XmlParent for the first time.

This one is really my fault for not reading the documentation, but I'm gonna blame it on CFDump anyway. See, like many people I am sure, when I am not positive what's inside of an object or I forget the name of something, I simply dump it out using CFDump. For example, if I wanted to see what was in a ColdFusion XML document, I could run this code:

  • <!--- Define the xml document. --->
  • <cfxml variable="xmlGirls">
  •  
  • <girls>
  • <girl>
  • <name>Christina Cox</name>
  • <hair>Dirty Blonde</hair>
  • </girl>
  • <girl>
  • <name>Maria Bello</name>
  • <hair>Dirty Blonde</hair>
  • </girl>
  • <girl>
  • <name>Winona Ryder</name>
  • <hair>Brunette</hair>
  • </girl>
  • </girls>
  •  
  • </cfxml>
  •  
  • <!--- Output ColdFusion XML document. --->
  • <cfdump
  • var="#xmlGirls#"
  • label="xmlGirls"
  • />

When we run this code, we get the following CFDump output:

 
 
 
 
 
 
XmlParent Not Shown In Long Version Of CFDUMP On Xml Documents. 
 
 
 

This is great - this really shows us what's in the XML document. Now, this is the "long version" XML output as shown by ColdFusion's CFDump tag, but as it turns out, this is not the complete XML architecture. To avoid what I assume is a circular reference issue, ColdFusion never outputs the XmlParent reference in the CFDump tag. Every child node has an XmlParent reference that allows you to get a reference to the child node's parent, thereby allowing you to walk both up and down the XML tree.

I can't believe I didn't know this!! When I was trying to answer an "Ask Ben" question earlier this week, I literally thought to myself, "There's got to be a better way," and decided, out of the blue, to Google, "XmlParent". Lo and behold, the first search result was the ColdFusion Live Docs' XML entry. How sad is that? I've been working with XML in ColdFusion for how many years? And I just discover XmlParent? That is sooo lame!

So anyway, embarrassment aside, let's just take a look at a quick example. Here, we are going to gather XML nodes via XmlSearch() and then use the resultant nodes' parent element to output data:

  • <!--- Gather all hair nodes that are dirty. --->
  • <cfset arrDirtyGirls = XmlSearch(
  • xmlGirls,
  • "//hair[ contains( text(), 'Dirty' ) ]"
  • ) />
  •  
  • <!---
  • Now that we have the hair nodes, loop over them to
  • output the parent node (girl) and the hair color.
  • --->
  • <cfloop
  • index="xmlHairNode"
  • array="#arrDirtyGirls#">
  •  
  • <!---
  • Get a reference to the girl. The Girl node is
  • the parent of the Hair node and can be accessed
  • via XmlParent.
  • --->
  • <cfset xmlGirl = xmlHairNode.XmlParent />
  •  
  • <!--- Output name and hair color. --->
  • #xmlGirl.Name.XmlText# - #xmlGirl.Hair.XmlText#<br />
  •  
  • </cfloop>

When we run this code, we get the following output:

Christina Cox - Dirty Blonde
Maria Bello - Dirty Blonde

The example is actually pretty obvious; It's only a shame, it wasn't obvious a few years ago.

Note: I actually have mentioned XmlParent once before on this blog, about a year and a half ago. But, it has long since faded from my memory. I think that's actually MORE embarrassing than having never learned it :)




Reader Comments

What? Girls poo? Now I'm crushed. You'll be telling me that dogs fart next, but I refuse to believe it Mr. N. :)

Reply to this Comment

@Mike,

You raise a good point. Maybe the whole pooing thing is more of a "pseudo-science". I find that arguments like this cast serious doubts on the whole topic.

Reply to this Comment

Dude, are you spying on me? I was just looking at the results of my xmlSearch thinking how I could get the other data in the element. Totally did not think of the xmlParent since its not in the dump. Thanks.

Reply to this Comment

@RyanTJ,

Word up, they really should put it in the output. Obviously they can't output the values, but they could do something like:

[ XmlParent ][ Output not shown ]

That way, at least we'd remember, oh d'uh, it's in there.

Reply to this Comment

Post A Comment

You — Get Out Of My Dreams, Get Into My Comments
Live in the Now
Oops!
Comment Etiquette: Please do not post spam. Please keep the comments on-topic. Please do not post unrelated questions or large chunks of code. And, above all, please be nice to each other - we're trying to have a good conversation here.