我已经遵守php代码,它给出了一个字符串转换错误的数组,创建了类别和子类别树节点但是在编译时发生了错误,让我解释一下我得到了错误。
<?php
$conn = mysqli_connect('localhost','res_user','Res@123','res_db');
if (mysqli_connect_errno())
{
echo "Failed to connect to MySQL: " . mysqli_connect_error();
}
$sql = " SELECT * , category.id AS catId FROM category INNER JOIN sub_category ON category.id = sub_category.category_id
ORDER BY category.id, sub_category.category_id";
$res = mysqli_query($conn, $sql);
$categoryArray = array();
$oldCatId = 0;
while ($row = mysqli_fetch_assoc($res)) {
if ($row['catId'] != $oldCatId) {
$categoryArray[$row['catId']] = array(
'success' => true,
'category_' . $row['catId'] = array(
'cat_id' => $row["catId"],
'cat_name' => $row['cat_name'],
'cat_img' => $row['cat_img'],
'sub_category' => array(
'sub_id' => $row['category_id'],
'sub_name' => $row['sub_name']
)
)
);
$oldCatId = $row['catId'];
} else {
$categoryArray[$row['catId']]['category_' . $row['catId']]['sub_category'][] = array(
'sub_id' => $row['category_id'],
'sub_name' => $row['sub_name']
);
}
}
echo $categoryArray;
?>
答案 0 :(得分:0)
答案 1 :(得分:0)
错误消息的原因是代码正在尝试显示带有 echo 的数组。此构造仅用于显示字符串,而不是数组。只要您为PHP提供标量值(boolean,int,string,float),如果标量的数据类型不是字符串,PHP将暂时将其提升为字符串。
通常,您需要遍历数组以显示其元素的任何标量值,编写某种循环结构。 PHP为使用多维数组提供了极大的便利,函数 array_walk_recursive()与回调一起使用。下面是问题中提到的数组的变体,以便您了解如何将array_walk_recursive()与回调一起使用。现在PHP支持匿名函数,我们可以使用一个用于回调,如下所示:
<?php
$categoryArray[0]['category_0']['sub_category'][] = array(
'sub_id' => 500,
'sub_name' => '1a'
);
array_walk_recursive($categoryArray,
function($value,$key){
echo "$key: $value\n";
});
// output:
sub_id: 500
sub_name: 1a
array_walk_recursive()的优点在于它将遍历多维数组,并且回调显示任何可用数据。注意,回调需要按特定顺序排列参数,第一个参数必须对应一个元素的值,而第二个参数必须代表它的键。
另请参阅实时演示here。