3

我想用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,而当我从文本中读取时,它会保持原样。

IE

  • 文件版本:\ud83d\ude03\\ud83d\\ude03
  • 脚本版本:\ud83d\ude03本身

所以重点是如何防止它\变为\\.

我仍然没有找到答案。

4

1 回答 1

2

找到了我猜的答案。

请参阅以下链接: 如何使用转义的 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

于 2015-11-13T05:31:07.660 回答