我努力将递归函数中的值传递给另一种方法中的数组。我在下面写了我的递归函数。
function get_parent_basket_id($parent_id) {
if($parent_id==NULL){
return false;
}
$baskets = $this->Model_cds_clients->clients($parent_id)->result();
if(count($baskets)==0){
return false;
}
foreach ($baskets as $row) {
if($row->parent_id==0){
return $row->id;
} else {
$this->get_parent_basket_id($row->parent_id);
}
}
}
我的Model_cds_clients代码位于
之下function clients ($parent_id) {
$this->db->select('endpoint, parent_id');
$this->db->from('cds_clients');
$this->db->where('parent_id', $parent_id);
$this->db->where('active', 1);
$result = $this->db->get();
return $result;
}
我的模型的表格结构如下所示
id - int(11)
name - varchar(255)
endpoint - varchar(64)
active - tinyint(1)
parent_id - int(11)
下面是我的函数,我需要将变量传递给端点数组下的client_id。
public function __construct() {
parent::__construct();
$this->load->model('Model_story');
$this->get_parent_basket_id($parent_id);
$data = array(
'basket_id' => $this->basketId,
'story_id' => $this->storyId,
'payload' => $this->xmlString,
'endpoints' => array(
array(
'client_id' => XXXX,
'endpoint_url' => 'http://www.example.com/consume.php'
), )
);
$json_payload = json_encode($data);
请帮忙。
答案 0 :(得分:1)
我不确定这是不是你要找的东西,但它是什么对我有用
变化:
foreach ($baskets as $row) {
if($row->parent_id==0){
return $row->id;
} else {
$this->get_parent_basket_id($row->parent_id);
}
}
为:
foreach ($baskets as $row) {
if($row->parent_id==0){
return $row->id;
} else {
return $this->get_parent_basket_id($row->parent_id);
}
}
在你的递归函数中。这样,id实际上会被传回。
然后,在您的控制器中,将结果分配给变量,即
$parent_basket_id = $this->get_parent_basket_id($parent_id);
但是,它看起来并不像你将$ parent_id声明/传递给__construct()
所以我不确定这是如何工作的。
希望这有帮助!
答案 1 :(得分:1)
你的尾递归的基本情况看起来不太正确。您的直接电话需要返回结果。我重新考虑了你的方法如下:
function get_parent_basket_id($parent_id) {
if(!$parent_id){
return false;
}
// Your method chaining is missing brackets on $this->Model_cds_clients()
$baskets = $this->Model_cds_clients()->clients($parent_id)->result();
if(!count($baskets)){
return false;
}
foreach ($baskets as $row) {
if(!$row->parent_id){
return $row->id;
} else {
// Add a return here
return $this->get_parent_basket_id($row->parent_id);
}
}
}
我希望前面的代码可以帮到你。 :)