获取多维数组的值

get value to multidimensional array

我有 json 看起来像这样的文件:

{
"world": {
    "france": {
        "city": {
            "city_1": {
                "name": "paris",
                "titre": "lorem ipsum"
            },
            "city_2": {
                "name": "marseille",
                "titre": "dolor sit amet"
            }
        }
    },
    "usa": {
        "city": {
            "city_1": {
                "name": "new york",
                "titre": "lorem ipsum"
            },
            "city_2": {
                "name": "los angeles",
                "titre": "lorem ipsum"
            },
            "city_3": {
                "name": "portland",
                "titre": "lorem ipsum"
            }
        }
    }
}
}

我想显示带有城市的国家/地区列表,如下所示:

<option value="france" data-city="paris,marseille">france</option>
<option value="usa" data-city="new york,los angeles,portland">usa</option>

我试过类似的方法来显示国家,但我无法显示城市列表

    foreach ($data['world'] as $key => $value)
{

    $scenario .= '<option value="' . $key . ' data-city="">' . $key .'</option>';
}

城市位于子数组中,因此您需要在现有的 foreach 中执行第二个循环以遍历城市。

您可以创建一个新数组来捕获子循环中的各个城市名称,然后 implode() 它们在您的 <option>:

$cityArray = array();
foreach($values['city'] as $cityKey=>$cityValue) {
    $cityArray[] = $cityValue['name'];
}

$scenario .= '<option value="' . $key . ' data-city="'.implode(',',$cityArray).'">' . $key .'</option>';

这是一个工作示例:https://3v4l.org/l986m

cityimplode 中提取 name 元素:

foreach ($data['world'] as $key => $value)
{
    $cities = implode(',', array_column($value['city'], 'name'));
    $scenario .= '<option value="' . $key . '" data-city="' . $cities . '">' . $key .'</option>';
}