如何在数组中将所有值设置为false?

时间:2015-12-14 14:29:07

标签: php arrays array-key

我有这样的代码:

$iterator = 0;
while (($end = $sth->fetch()) && $iterator < 2)
{
    $api_arr["data"]['tc'][] =  $end["tc"];
    $api_arr["data"]['em'][] =  $end["em"];
    $api_arr["data"]['sg'][] =  $end["sg"];

    $iterator ++;
}

我为其他开发者创建了我的网站API。我给他们一个JSON输出。像这样:

{
   -data{
       tc: [
         "value_tc_1",
         "value_tc_2",
         "value_tc_3" 
       ],

       em: [
         "value_em_1",
         "value_em_2",
         "value_em_3" 
       ],

       sg: [
         "value_sg_1",
         "value_sg_2",
         "value_sg_3" 
       ]
   }
}

当前输出: (当没有任何行$sth->rowCount() == ''时)

[]

我想要的是什么: (当没有任何行$sth->rowCount() == ''时)

{
   -data{
       tc: [false],
       em: [false],
       sg: [false]
   }
}

嗯,我怎么能这样做?

作为咨询:当没有结果时,是否必须将false设置为数组的值?我从未有过创建API的经验。我想根据一些类似的API (来自其他网站)设置false

实际上我想向其他开发者提供一个标准并且可用。那么,我做的是API吗?其他开发人员可以使用它吗?

我不知道,也许我需要的是这个:

{
   -data{
       tc: false,
       em: false,
       sg: false
   }
}

一般来说,我需要知道什么? {事先感谢:)}

我尝试了什么:我认为这样的事情会有用,但实际上我不知道应该如何使用它:

array_fill_keys(array_keys($api_arr['data']), "false");

2 个答案:

答案 0 :(得分:3)

使用空值启动数组:

$iterator = 0;
$api_arr = [
    'data'=>
        [
            'tc'=>[],
            'em'=>[],
            'sg'=>[]
        ]
    ];

while (($end = $sth->fetch()) && $iterator < 2)
{
    $api_arr["data"]['tc'][] =  $end["tc"];
    $api_arr["data"]['em'][] =  $end["em"];
    $api_arr["data"]['sg'][] =  $end["sg"];

    $iterator ++;
}

如果数据库中没有结果,则结果为:

{
   data{
       tc: [],
       em: [],
       sg: []
   }
}

对于期望包含数组的数据结构的API使用者而言,这将是一致的。可能整个结构都可以重构,但一致性是一个好的开始

要展开"the whole structure can be refactored"部分,查看数据,似乎值在逻辑上分组在数据库中(一行包含相关的tcem和{{1}但是你没有明确的理由将它们分开在API中。

更好的结构是遵循数据库的结构:

sg

这将输出:

$iterator = 0;
$data = [];
while (($end = $sth->fetch()) && $iterator < 2)
{
    $data[] =  [
        'tc'=> $end["tc"],
        'em'=> $end["em"],
        'sg'=> $end["sg"]
   ];
    $iterator ++;
}
header('Content-Type: application/json');
echo json_encode([data=>$data]);

如果有结果,并且:

{
    data:[
       {tc: value_tc_1, em: value_em_1, sg: value_sg_1},
       {tc: value_tc_2, em: value_em_2, sg: value_sg_2},
       {tc: value_tc_3, em: value_em_3, sg: value_sg_3}
    ]
}

没有结果时。

消费者代码可以是例如(再次使用php,可以是任何语言):

{
    data:[]
}

无论你的api是否返回结果,消费者代码都运行良好(如果没有结果,只显示一个空表)。

最后请注意,如果您的SQL更符合您的要求,例如:

 $response = json_decode(file_get_contents($apiEndpoint));
 foreach($response->data as $element){
     echo '<tr><td>' . $element->tc . '</td><td>' . $element->em . '</td><td>' . $element->sg . '<td></tr>';
 }

然后你的整个PHP代码变成:

SELECT tc, em, sg FROM tablename LIMIT 3

不需要迭代器,while循环等

答案 1 :(得分:1)

返回错误对象可保持一致性,并且很容易在客户端捕获:

假如没有找到数据,则返回此信息:

$api_arr["error"]["code"] = 404;
$api_arr["error"]["message"] = "No data found";

现在在客户端,在ajax请求中,有人可以轻松地执行此操作:

try {
   if(typeof ajaxObj.error != 'undefined'){
        throw ajaxObj.error;
   }

   //Data is found
} catch(errObj) {
   //Handle the error object.
}