带有 Javascript 的表情符号代理字符串。如何解析?

emoji surrogate string with Javascript. How to parse?

我想用javascript表达表情。 我有一个文件...

:-),\ud83d\ude03
^^,\ud83d\ude03
^_^,\ud83d\ude03
:),\ud83d\ude03
:D,\ud83d\ude03

其中包含密钥和表情符号代理作为值。 我要读这个,如果输入的字符串与键匹配,用那些表情符号替换这个词。

即输入“^^”将替换为笑脸标记。

但有些奇怪,如果我将这些信息作为对象,它会很好地打印表情符号。

喜欢...

this.emojiStore.osx = {
                //smile
                ':-)' : '\ud83d\ude03'
                , '^^' : '\ud83d\ude03'
                , '^_^' : '\ud83d\ude03'
                , ':)' : '\ud83d\ude03'
                , ':D' : '\ud83d\ude03'
                //frawn
                , ':(' : '\ud83d\ude1e'
                //crying
                , 'T^T' : '\ud83d\ude22'
                , 'T_T' : '\ud83d\ude22'
                , 'ㅜㅜ' : '\ud83d\ude22'
                , 'ㅠㅠ' : '\ud83d\ude22'
                //poo 
                , 'shit' : '\ud83d\udca9'
        };

并替换部分看起来像...

this.value = emojiList[key];

但是当我从文件中读取信息时,它会打印类似“\ud83d\ude22”的字符串。

如何用 js 表达代理字符串?(我不想使用 3rd 方库。)

仅供参考,js 文件和目标文件均使用 UTF-8 编码。

========文件加载部分

function loadFile(url){
    var ret = {};
    var rawFile = new XMLHttpRequest();
//    rawFile.overrideMimeType('text/html; charset=utf-8');
    rawFile.open("GET", url, false);
    rawFile.onreadystatechange = function (){
        if(rawFile.readyState === 4){
            if(rawFile.status === 200 || rawFile.status == 0) {
                var allText = rawFile.responseText;
                var textByLine = allText.split('\n');
                for(var i = 0; i < textByLine.length; i++){
                    if(textByLine[i].trim().length < 1) continue;
                    var key = textByLine[i].split(',')[0].trim();
                    var value = textByLine[i].split(',')[1].trim();
                    ret[key] = value;
                }
            }
        }
    };
    rawFile.send(null);
    console.log(ret);
    return ret;
}

=========== 已编辑

我找到了提示。

当我从文件中读取时,它会 \u 变为 \u,而当我从文本中读取时,它会保持原样。

关键是如何防止它从 \ 更改为 \

虽然我仍然没有找到答案。

找到了我猜的答案。

参考关注 link : How do I decode a string with escaped unicode?

function parseUnicode(str){
    var r = /\u([\d\w]{4})/gi;
    str = str.replace(r, function (match, grp) {
        return String.fromCharCode(parseInt(grp, 16)); } );
    return str;
}

作为参考,js 字符串值可以与来自文件的字符串不同。我做了一个函数来检查每个字符和结果是不同的。

function charAnalyst(str){

    var result = '';
    for(var i = 0; i < str.length; i++){
        var aChar = str.charAt(i);
        result += aChar;
        console.log(aChar);
    }
    console.log(result);
}

我希望这会节省您的时间:D