Skip to content Skip to sidebar Skip to footer

Converting A Php Array Into Html Form Inputs Is Duplicating Items

I am attempting to take an array of values and build a php form from those values. The array is at the bottom to keep the question clear. The array structure is: - Item - Item - It

Solution 1:

functionrenderTest2(array$data)
{
    $html = '<ul>';
    foreach ($dataas$item) {
        $html .= '<li>';
        if (array_key_exists('children', $item)) {
            $html .= $item['name'];
            $html .= renderTest2($item['children']);
        } else {
            $html .= $item['name'] . "<input type='text' value=''> <br/>";
        }
        $html .= '</li>';
    }
    $html .= '</ul>';

    return$html;
}

you are looping two times which is not required and if it has children pass children array only

Explanation:

  1. Loop through an array and if it has children key do recursion
  2. If not found generate li element

Solution 2:

Looking at the code i saw the following mistake:

foreach() do foreach() so a multiple foreach() loop would be the mistake you've made.

try this code:

by calling foreach() only once and using

if (array_key_exists('children', $item)) {
   $html .= $item['name'];
   $html .= renderTest2($item['children']);
}

together in one foreach() the double loop isn't needed and recursion is avoided

The full code then would be:

<?php$aFullArray = array();


$aFullArray[] = array("name" => "Adam", "address" => "123 main", "phone" => "000-000-0000");
$aFullArray[] = array("name" => "Beth", "address" => "123 main", "phone" => "000-000-0000");


$aChildren = array();
$aChildren [] = array("name" => "Mike", "address" => "123 main", "phone" => "000-000-0000");
$aChildren[] = array("name" => "Nancy", "address" => "123 main", "phone" => "000-000-0000");


$subChild = array();
$subChild [] = array("name" => "Peter", "address" => "123 main", "phone" => "000-000-0000");
$subChild [] = array("name" => "Paul", "address" => "123 main", "phone" => "000-000-0000");

$aChildren [] = array("name"     => "Oscar", "address" => "123 main", "phone" => "000-000-0000",
    "children" => $subChild);

$aFullArray[] = array("name"     => "Charlie", "address" => "123 main", "phone" => "000-000-0000",
    "children" => $aChildren);

$aFullArray[] = array("name" => "Danny", "address" => "123 main", "phone" => "000-000-0000");

functionrenderTest2(array$data)
{
    $html = '<ul>';
    foreach ($dataas$item) {
        $html .= '<li>';
        if (array_key_exists('children', $item)) {
            $html .= $item['name'];
            $html .= renderTest2($item['children']);
        } else {
            $html .= $item['name'] . "<input type='text' value=''> <br/>";
        }
        $html .= '</li>';
    }
    $html .= '</ul>';

    return$html;
}
echo renderTest2($aFullArray);

Hope this helps!

Solution 3:

As the original code was not making use of various elements within the source arrays I simplified for testing porpoises. Hopefully the following makes sense, it seems to generate the list in the desired manner.

$html = $family = $children_family_1 = $children_family_2 = array();




$family[] = array("name" => "Adam");
$family[] = array("name" => "Beth");
$family[] = array("name" => "Danny");

$children_family_2[] = array("name" => "Peter");
$children_family_2[] = array("name" => "Paul");

$children_family_1[] = array("name" => "Mike");
$children_family_1[] = array("name" => "Nancy");

$children_family_1[] = array("name" => "Oscar", "children" => $children_family_2 );
$family[] = array("name" => "Charlie", "children" => $children_family_1 );



functionfamilytree($input=array(),&$html){
    $html[]='<ul>';
    foreach( $inputas$index => $arr ){
        if( array_key_exists( 'children', $arr ) && is_array( $arr['children'] ) ){

            $html[]="<li>Parent: {$arr['name']}</li>";
            $html[]="<li>";

            /* recurse array to repeat structure */
            familytree( $arr['children'], &$html );

            $html[]="</li>";
        } else {
            $html[]="<li><input type='text' name='name[]' value='{$arr['name']}' /></li>";
        }
    }
    $html[]='</ul>';

    return implode( PHP_EOL, $html );
}

echo familytree( $family, $html );

The generated html:

<ul><li><inputtype="text"name="name[]"value="Adam"></li><li><inputtype="text"name="name[]"value="Beth"></li><li><inputtype="text"name="name[]"value="Danny"></li><li>Parent: Charlie</li><li><ul><li><inputtype="text"name="name[]"value="Mike"></li><li><inputtype="text"name="name[]"value="Nancy"></li><li>Parent: Oscar</li><li><ul><li><inputtype="text"name="name[]"value="Peter"></li><li><inputtype="text"name="name[]"value="Paul"></li></ul></li></ul></li></ul>

Post a Comment for "Converting A Php Array Into Html Form Inputs Is Duplicating Items"