基于 数组相关函数 操作数组后,同样的输入,在不同执行顺序下的差异的分析(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);
永夜