PHP7.2引入了一种行为上的更改,以转换对象和数组类型转换中的数字键,从而解决了这一特殊的不一致问题,并使以下所有示例的行为均符合预期。
少一件值得困惑的事情!
PHP拥有许多黑暗的小巷,您 确实 不想在其中发现自己。名称为数字的对象属性是其中之一…
$a = array('123' => '123', '123foo' => '123foo');
$o = (object)$a;
echo $o->123foo; // error
您 可以 使用大括号语法访问此类属性
$a = array('123' => '123', '123foo' => '123foo');
$o = (object)$a;
echo $o->{'123foo'}; // OK!
$a = array('123' => '123', '123foo' => '123foo');
$o = (object)$a;
echo $o->{'123foo'}; // OK!
echo $o->{'123'}; // error!
好吧,除非对象不是最初来自数组。
$a = array('123' => '123');
$o1 = (object)$a;
$o2 = new stdClass;
$o2->{'123'} = '123'; // setting property is OK
echo $o1->{'123'}; // error!
echo $o2->{'123'}; // works... WTF?
很直观,你不同意吗?
最实用的方法只是将您感兴趣的对象转换回数组,这将允许您访问属性:
$a = array('123' => '123', '123foo' => '123foo');
$o = (object)$a;
$a = (array)$o;
echo $o->{'123'}; // error!
echo $a['123']; // OK!
不幸的是,这不是递归的。因此,在您的情况下,您需要执行以下操作:
$highlighting = (array)$myVar->highlighting;
$data = (array)$highlighting['448364']->Data;
$value = $data['0']; // at last!
function recursive_cast_to_array($o) {
$a = (array)$o;
foreach ($a as &$value) {
if (is_object($value)) {
$value = recursive_cast_to_array($value);
}
}
return $a;
}
$arr = recursive_cast_to_array($myVar);
$value = $arr['highlighting']['448364']['Data']['0'];
但是,我不认为这是一个更好的选择,因为它会不必要地将所有您 不 感兴趣的属性以及您所 不 感兴趣的属性强制转换为数组。
$arr = json_decode(json_encode($myVar), true);
$value = $arr['highlighting']['448364']['Data']['0'];
JSON函数有助于对数组进行递归转换,而无需定义任何外部函数。无论看上去多么理想,它都具有选项#2的“ nuke”缺点, 另外还有_一个缺点,即如果对象中有任何字符串,则这些字符串 _必须 以UTF-8编码(这是的要求json_encode