这是我的代码。
$query = $this->db->query($sql);
$m &= is_object($emp) ? $emp->mobile_no : $emp['mobile_no'];
foreach ($query->result() as $row) {
$m [] = $row->mobile_no;
}
它警告不能将标量值用作数组。我的简单解决方案是这个
$query = $this->db->query($sql);
foreach ($query->result() as $row) {
if (is_object($emp)) {
$emp->mobile_no[] = $row->mobile_no;
} else {
$emp['mobile_no'][] = $row->mobile_no;
}
}
但现在,在每个循环中,它都会做一些相同的事情。我能做什么?这就是我期望创造的。
contacts: {
address: "329/A",
corresponding_address: "Negambo",
mobile_no: [
"0719896992",
"0713345582"
],
telephone_no: [
"0915717472",
"0915715094"
]
}
////////////////////////////////更新
好的,我用这种方式修复
$query = $this->db->query($sql);
$tel = array();
foreach ($query->result() as $row) {
$tel[] = $row->telephone_no;
}
if (is_object($emp)) {
$emp->telephone_no = $tel;
} else {
$emp['telephone_no'] = $tel;
}
为什么不以正确的方式使用$m
$query = $this->db->query($sql);
$m = array();
$m[] = is_object($emp) ? $emp->mobile_no : $emp['mobile_no'];
foreach ($query->result() as $row) {
$m [] = $row->mobile_no;
}
当然,我在不知道$emp
是什么的情况下这么说。我在这里假设它至少等价于$row
,因为他们确定了这个性质$row->mobile_no
。