0

我有一个简单的函数checkReplies()来检查reply_id并且如果reply_id不等于0,则调用自己并再次检查。现在我需要为它生成的输出创建一个数组 f ,但我做不到,数组只输出最后一个元素

function checkReplies( $rnid ){
    $r_notes = array();
    include_once('include/class.dbc.php');
    $dbo=new dbc();
    $db=$dbo->dbconnect();
    if( $rnid > 0 ): 
    $qry_rn = "SELECT note_subject,note_body,reply_note_id FROM tbl_notes WHERE note_id = '$rnid' ORDER BY note_date DESC";
    $rslt_rn = $dbo->executeQuery( $qry_rn );
    $reply = '<p style="border : none;">';
    $reply .= $rslt_rn[0]['note_subject'].'<br />'.$rslt_rn[0]['note_body'];
    $reply .= '('.$rslt_rn[0]['reply_note_id'].')';
    $reply .= '</p>';

    echo $reply;
    $r_notes[] = $reply;
    checkReplies( $rslt_rn[0]['reply_note_id'] );
    endif;
    return $r_notes;
}
$display = checkReplies( $rnid );
var_dump($display);

如何创建输出数组?

4

2 回答 2

1

只需将您的数组作为函数的可选参数即可。并且,返回函数的递归调用。

几乎所有的递归函数都是以相同的方式构建的:在开始时,一个使你的递归停止或继续的条件:这被称为“终止情况”。然后,如果这个中断条件不成立,就做你必须做的事情并返回函数的递归调用。

function checkReplies( $rnid, &$r_notes = array() ){

    include_once('include/class.dbc.php');
    $dbo=new dbc();
    $db=$dbo->dbconnect();

    if($rnid == 0)
            return $r_notes;

    $qry_rn = "SELECT note_subject,note_body,reply_note_id FROM tbl_notes WHERE note_id = '$rnid' ORDER BY note_date DESC";
    $rslt_rn = $dbo->executeQuery( $qry_rn );

    $reply = '<p style="border : none;">';
    $reply .= $rslt_rn[0]['note_subject'].'<br />'.$rslt_rn[0]['note_body'];
    $reply .= '('.$rslt_rn[0]['reply_note_id'].')';
    $reply .= '</p>';

    echo $reply;

    $r_notes[] = $reply;

    return checkReplies( $rslt_rn[0]['reply_note_id'], $r_notes );

}


$display = checkReplies( $rnid );

var_dump($display);
于 2013-09-24T09:25:17.487 回答
1

尝试这个

$r_notes = array_merge($r_notes, checkReplies( $rslt_rn[0]['reply_note_id'] ));

代替

$r_notes[] = $reply;

checkReplies( $rslt_rn[0]['reply_note_id'] );

我编辑了,抱歉错误。

于 2013-09-24T09:27:27.123 回答