0

この再帰関数のバージョンを変更しました... http://www.phpbuilder.com/articles/databases/mysql/handling-hierarchical-data-in-mysql-and-php.html

必要なのは、この関数の戻り値を配列に保存して、配列要素の順序を逆にする方法です。関数はうまく機能しますが、値を保存する方法が必要です。これがコードです...

function display_children($category_id, $level) {
  global $database;
  $result = mysql_query("SELECT * FROM parents WHERE id_roditelja='$category_id'") or die(mysql_error());
  $niz = array();
  while ($row = mysql_fetch_array($result)) {
    echo str_repeat('  ', $level) . $row['naziv'] . "<br/>";
    array_push($niz, display_children($row['parent_id'], $level + 1));
//this is one way I tried, and I get $niz with exact number of elements but each is null
//in this $niz array I need to store values of recursion
    var_dump($niz);
  }
}
4

1 に答える 1

2

私はあなたがこれを望んでいると思います:

function display_children/* <- this must be the same */($category_id, $level) {
  global $database;
  $result = mysql_query("SELECT * FROM parents WHERE id_roditelja='$category_id'") or     die(mysql_error());
  $niz = array();
  while ($row = mysql_fetch_array($result)) {
    $niz[] = str_repeat('  ', $level) . $row['naziv'] . "<br/>"; // we need to save this
    $niz = array_merge($niz, /* as this -> */display_children($row['parent_id'], $level + 1)); // array_merge doesn't take a reference so we need to store its result in $niz
  }
  return $niz;
}

ツリーのような構造が必要な場合は、array_merge の代わりに array_push を使用します。誰も気づいていないようですが、彼の関数は return ステートメントなしでは何も返すことができません!

于 2013-08-28T09:02:53.360 に答える