基于 数组相关函数 操作数组后,同样的输入,在不同执行顺序下的差异的分析(include、引用)
1、参考:在 Laravel 6 中,基于 数组相关函数 操作数组后,同样的输入,在不同执行顺序下的差异的分析(include、引用)。https://www.shuijingwanwq.com/2023/06/13/7716/
2、当时的解决方案:将 $value 替换为 $sectionSettingValue,临时规避掉引用的变量名重名的问题
3、之后又存在类似的问题,需要能够快速定位是哪些变量重名导致的问题。决定将执行有误的文件中的变量都在文件开头打印出来。最后将打印结果中不为 null 的,全部 unset() 掉。
\Illuminate\Support\Facades\Log::info(
'schema.v2.1.80',
[
'$sectionKey' => $sectionKey ?? null,
'$section' => $section ?? null,
'$blockKey' => $blockKey ?? null,
'$block' => $block ?? null,
'$blockOrderKey' => $blockOrderKey ?? null,
'$blocks' => $blocks ?? null,
]
);
4、打印结果如下,确认在上一次的执行后,变量:$sectionKey、$section、$blockKey、$block、$blockOrderKey、$type 皆不为 null,全部需要销毁掉。
[2023-09-04 10:43:45] local.INFO: schema.v2.1.80 {
"$sectionKey": "image-1",
"$section": {
"type": "image",
"disabled": false,
"settings": {
"heading": "",
"heading_align": "center"
},
"blocks": {
"column-0": {
"type": "column",
"settings": {
"image": "https://xxx-s3.s3.us-east-2.amazonaws.com/image/736589fac73c7dfdbf61efadb49a95fb9af16efb.jpeg",
"mobile_image": "https://cdn.xxx.com/image/2022/03/200062b82e8cbae7cf7c48b425a33260686fd4aa3e6ed656901cb4cc7a283487.jpeg",
"url": "/"
}
},
"column-1": {
"type": "column",
"settings": {
"image": "https://xxx-s3.s3.us-east-2.amazonaws.com/image/736589fac73c7dfdbf61efadb49a95fb9af16efb.jpeg",
"mobile_image": "https://cdn.xxx.com/image/2022/03/200062b82e8cbae7cf7c48b425a33260686fd4aa3e6ed656901cb4cc7a283487.jpeg",
"url": "/"
}
}
}
},
"$blockKey": "column-1",
"$block": {
"type": "column",
"settings": {
"image": "https://xxx-s3.s3.us-east-2.amazonaws.com/image/736589fac73c7dfdbf61efadb49a95fb9af16efb.jpeg",
"mobile_image": "https://cdn.xxx.com/image/2022/03/200062b82e8cbae7cf7c48b425a33260686fd4aa3e6ed656901cb4cc7a283487.jpeg",
"url": "/"
}
},
"$blockOrderKey": 8,
"$type": [
"search",
"all_collections"
]
}
5、销毁变量的代码如下
unset($sectionKey, $section, $blockKey, $block, $blockOrderKey, $type);
近期评论