需要在JavaScript中转义非ASCII字符

时间:2011-09-21 12:07:45

标签: javascript

是否有任何功能可以执行以下操作?

var specialStr = 'ipsum áá éé lore';
var encodedStr = someFunction(specialStr);
// then encodedStr should be like 'ipsum \u00E1\u00E1 \u00E9\u00E9 lore'

我需要编码超出ASCII范围的字符,并且需要使用该编码进行编码。我不知道它的名字。它可能是Unicode吗?

4 个答案:

答案 0 :(得分:12)

这应该可以解决问题:

function padWithLeadingZeros(string) {
    return new Array(5 - string.length).join("0") + string;
}

function unicodeCharEscape(charCode) {
    return "\\u" + padWithLeadingZeros(charCode.toString(16));
}

function unicodeEscape(string) {
    return string.split("")
                 .map(function (char) {
                     var charCode = char.charCodeAt(0);
                     return charCode > 127 ? unicodeCharEscape(charCode) : char;
                 })
                 .join("");
}

例如:

var specialStr = 'ipsum áá éé lore';
var encodedStr = unicodeEscape(specialStr);

assert.equal("ipsum \\u00e1\\u00e1 \\u00e9\\u00e9 lore", encodedStr);

答案 1 :(得分:1)

只是为了获取您可以做的信息,如Domenic所说或使用escape函数,但这将生成具有不同格式的unicode(更适​​合浏览器):

>>> escape("áéíóú");
"%E1%E9%ED%F3%FA"

答案 2 :(得分:0)

如果您需要十六进制编码而不是unicode,那么您可以简化@ Domenic的答案:

"aäßåfu".replace(/./g, function(c){return c.charCodeAt(0)<128?c:"\\x"+c.charCodeAt(0).toString(16)})

returns: "a\xe4\xdf\xe5fu"

答案 3 :(得分:0)

这对我有用。特别是在使用Dropbox REST API时:

   encodeNonAsciiCharacters(value: string) {
        let out = ""
        for (let i = 0; i < value.length; i++) {
            const ch = value.charAt(i);
            let chn = ch.charCodeAt(0);
            if (chn <= 127) out += ch;
            else {
                let hex = chn.toString(16);
                if (hex.length < 4)
                    hex = "000".substring(hex.length - 1) + hex;
                out += "\\u" + hex;
            }
        }
        return out;
    }