Sample code for 30+ languages & platforms
Delphi ActiveX

Xml TagPath Property Explained

See more XML Examples

Demonstrates and explains the TagPath property.

Note: The TagPath property was introduced in Chilkat v9.5.0.77

Chilkat Delphi ActiveX Downloads

Delphi ActiveX
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
xml: TChilkatXml;
found: Integer;
tagPath: WideString;

begin
success := 0;

xml := TChilkatXml.Create(Self);

// Load some XML:
success := xml.LoadXml('<a><bbb><ccc><ddd>1</ddd><ddd><z>zzz</z></ddd><ddd>3</ddd></ccc></bbb></a>');

Memo1.Lines.Add(xml.GetXml());

// This is what we have:

// <?xml version="1.0" encoding="utf-8"?>
// <a>
//     <bbb>
//         <ccc>
//             <ddd>1</ddd>
//             <ddd>
//                 <z>zzz</z>
//             </ddd>
//             <ddd>3</ddd>
//         </ccc>
//     </bbb>
// </a>

// The TagPath property is read-only property that returns the unique path to the
// node from the document root.

// For example:
found := xml.SearchForTag2(xml.ControlInterface,'z');
if (found = 1) then
  begin
    // We found a node having the tag "z".
    // The TagPath property tells us the location in the document.
    tagPath := xml.TagPath;
    Memo1.Lines.Add(tagPath);

    // The tagPath is bbb|ccc|ddd[1]|z

    // If we to back to the document root, we can get to the given node via the tagPath.
    xml.GetRoot2();
    Memo1.Lines.Add(xml.Tag);
    // The root tag is "a".

    // Follow the tagPath to the "z" node:
    found := xml.FindChild2(tagPath);
    Memo1.Lines.Add('found = ' + IntToStr(Ord(found)) + ', tag = ' + xml.Tag);
    // We are now at "z".

  end;
end;