同一段代码vue 和js中结果不同 涉及中文对比大小的问题

目前在做通讯录字母排序这样一个需求 然后同一段代码vue中结果和原生js中结果不同 涉及到了中文对比首字母排序问题
vue代码

img


结果错误

img

原生js代码
function LoadData(arr) {
if (!String.prototype.localeCompare) return null;
let letters = "ABCDEFGHJKLMNOPQRSTWXYZ".split("");
let zh = "阿八嚓哒妸发夹呵几咔啦姆南噢妑七呥扨侤穵夕丫帀".split("");

        let segs = [];
        letters.map((items, i) => {
            let cur = { letter: items, data: [] };
            arr.map((item) => {
                if (
                    item.name.slice(0, 1).localeCompare(zh[i]) >= 0 &&
                    item.name.slice(0, 1).localeCompare(zh[i + 1]) < 0
                ) {
                    cur.data.push(item);
                }
            });
            if (cur.data.length != 0) {
                cur.data.sort(function (a, b) {
                    return a.name.localeCompare(b.name, "zh");
                });
                segs.push(cur);
            }
        });
        console.log(segs);
        return segs;
    }
    LoadData([
        {
            name: "张三",
        },
        {
            name: "李四",
        },
    ]);

结果正确

img

我无法复现你的错误,同一段代码我在js文件中,ts文件中,.vue文件中运行,结果都是正确的