Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 545579
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T10:46:34+00:00 2026-05-13T10:46:34+00:00

I’m trying to loop through multiple <LineItemInfo> products contained within a <LineItems> within XML

  • 0

I’m trying to loop through multiple <LineItemInfo> products contained within a <LineItems> within XML I’m parsing to pull product Ids out and send emails and do other actions for each product.

The problem is that it’s not returning anything. I’ve verified that the XML data is valid and it does contain the necessary components.

$itemListObject = $orderXML->getElementsByTagName('LineItemInfo');
var_dump($itemListObject->length);
var_dump($itemListObject);

The output of the var_dump is:

int(0)
object(DOMNodeList)#22 (0) {
}

This is my first time messing with this and it’s taken me a couple of hours but I can’t figure it out. Any advice would be awesome.

EDIT:

My XML looks like this… except with a lot more tags than just ProductId

<LineItems>
     <LineItemInfo>
         <ProductId href='[URL_TO_PRODUCT_XML]'>149593</ProductId>
     </LineItemInfo>
     <LineItemInfo>
         <ProductId href='[URL_TO_PRODUCT_XML]'>149593</ProductId>
     </LineItemInfo>
</LineItems>

Executing the following code does NOT get me the ProductId

$itemListObject = $orderXML->getElementsByTagName('LineItemInfo');
foreach ($itemListObject as $element) { 
        $product = $element->getElementsByTagName('ProductId');
        $productId = $product->item(0)->nodeValue;
        echo $productId.'-';
}

EDIT #2

As a side note, calling

$element->item(0)->nodeValue

on $element instead of $product caused my script’s execution to discontinue and not throwing any errors that were logged by the server. It’s a pain to debug when you have to run a credit card to find out whether it’s functioning or not.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-13T10:46:35+00:00Added an answer on May 13, 2026 at 10:46 am

    DOMDocument stuff can be tricky to get a handle on, because functions such as print_r() and var_dump() don’t necessarily perform the same as they would on normal arrays and objects (see this comment in the manual).

    You have to use various functions and properties of the document nodes to pull out the data. For instance, if you had the following XML:

    <LineItemInfo attr1="hi">This is a line item.</LineItemInfo>
    

    You could output various parts of that using:

    $itemListObjects = $orderXML->getElementsByTagName('LineItemInfo');
    foreach($itemListObjects as $node) {
        echo $node->nodeValue;    //echos "This is a line item."
        echo $node->attributes->getNamedItem('attr1')->nodeValue;  //echos "hi"
    }
    

    If you had a nested structure, you can follow basically the same procedure using the childNodes property. For example, if you had this:

    <LineItemInfo attr1="hi">
      <LineItem>Line 1</LineItem>
      <LineItem>Line 2</LineItem>
    </LineItemInfo>
    

    You might do something like this:

    $itemListObjects = $orderXML->getElementsByTagName('LineItemInfo');
    foreach($itemListObjects as $node) {
        if ($node->hasChildNodes()) {
          foreach($node->childNodes as $c) {
             echo $c->nodeValue .",";
          }
        }
    }
    
    //you'll get output of "Line 1,Line 2,"
    

    Hope that helps.

    EDIT for specific code and XML

    I ran the following code in a test script, and it seemed to work for me. Can you be more specific about what’s not working? I used your code exactly, except for the first two lines that create the document. Are you using loadXML() over loadHTML()? Are there any errors?

    $orderXML = new DOMDocument();
    $orderXML->loadXML("
    <LineItems>
         <LineItemInfo>
             <ProductId href='[URL_TO_PRODUCT_XML]'>149593</ProductId>
         </LineItemInfo>
         <LineItemInfo>
             <ProductId href='[URL_TO_PRODUCT_XML]'>149593</ProductId>
         </LineItemInfo>
    </LineItems>
    ");
    
    $itemListObject = $orderXML->getElementsByTagName('LineItemInfo');
    foreach ($itemListObject as $element) { 
        $product = $element->getElementsByTagName('ProductId');
        $productId = $product->item(0)->nodeValue;
        echo $productId.'-';
    }
    
    //outputs "149593-149595-"
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.