需要在JavaScript中转义非ASCII字符

问题描述 投票:4回答:4

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

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

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

javascript
4个回答
13
投票

这应该做的伎俩:

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
投票

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

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

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"

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;
    }
© www.soinside.com 2019 - 2024. All rights reserved.