数组中的PHP复选框

时间:2009-12-14 06:57:37

标签: php

当表单发布时,我会得到一些复选框值,如下所示:

Array ( [chk0] => true ,
        [chk1] => true,
        [chk3] => true,
        [chk1002] => on,
        [chk1005] => on 
      ) 

使用PHP,如何使用上述变量构建这样的JSON请求?

        "data":
        [
            {
                "checkboxval": true,
                "id": 0
            },
            {
                "checkboxval": true,
                "id": 1
            },
            {
                "checkboxval": true,
                "id": 3
            },
            {
                "checkboxval": true,
                "id": 1002
            },
            {
                "checkboxval": true,
                "id": 1005
            }
        ]

请注意我的POST变量也可以包含其他表单变量,但所有复选框值都将使用前缀“chk”命名

5 个答案:

答案 0 :(得分:1)

$output = array();
foreach ($input as $k => $v) {
  $output[] = array(
    'checkboxval' => !!$v,
    'id' => preg_replace('!^chk!', '', $k),
  );
}
header('Content-Type: application/json');
echo json_encode(array('data' => $output));

答案 1 :(得分:1)

foreach ($_POST as $k => $v) {
  $output[] = array(
    'checkboxval' => ($v=='on'? true : ($v=='off' ? false : !!$v)),
    'id' => preg_replace('!^chk!', '', $k),
  );
}
header('Content-Type: application/json');
echo json_encode(array('data' => $output));

致于提供此代码基础的cletus的信用。

答案 2 :(得分:0)

看一下json_encode() php函数。你需要按一下你的阵列来获得你想要的JSON格式。

答案 3 :(得分:0)

以下是一个例子......

$_POST["chk1"] = "Hello";
$_POST["chk2"] = "World";
$jsonArray = array();
foreach($_POST as $key => $val){
  if(preg_match("/chk/", $key)){
    $jsonArray[$key] = $val;
  }
}
$jsonArray = array("Data" => $jsonArray);
$json = json_encode($jsonArray);
echo "<pre>";
echo $json;
echo "</pre>";

输出:

{"Data":{"chk1":"Hello","chk2":"World"}}

答案 4 :(得分:0)

我还没有测试过这个,但也许是这样的:

$json = '"data": [';
$first = true;
foreach ($_POST as $k => $v){
    if (preg_match('/^chk(\d+)$/', $k, $m)){
        if ($first) $first = false; else $json .= ", ";
        $json .= sprintf('{ "checkboxval" : %s, "id" : %s }', ($v && $v != "off") ? "true" : "false", $m[1]);
    }
}
$json .= ']';