JS中unicode和utf-8的转换

JS中unicode和utf-8的转换

最近公司找了几个py写后端项目,后端接口中返回 ‘\xe6\x88\x91\xe4\xbb\xac‘ 类似的编码,我看着就很好奇,于是将此段编码过的字符输入chrome的控制台,结果如下:

> ‘\xe6\x88\x91\xe4\xbb\xac‘
< "??????"

JS中unicode和utf-8的转换

很明显,由于解释错误出现了乱码问题。。。

在网上一番搜索发现,这就是utf-8编码,本着好奇,就想知道unicode和utf-8之间是如何转换的。。。至于utf-8和unicode的区别,我只强调一点 UTF-8是 Unicode 的实现方式之一 ,具体的话大家网上自行查找,这里提供我参考的文章 字符编码笔记:ASCII,Unicode 和 UTF-8,下面我总结下在js中这两种编码之间如何转换

unicode转utf-8

我们知道在js中,encodeURI和encodeURIComponent函数将URI转为utf-8编码:

> encodeURIComponent(‘深圳华强‘)
< "%E6%B7%B1%E5%9C%B3%E5%8D%8E%E5%BC%BA"

在网上验证下没问题:
JS中unicode和utf-8的转换

/**
* 
* @param str {String}
* @return {Array{Number}}
*/
function encodeUTF8 (str = ‘深圳华强‘) {
    let str1 = encodeURIComponent(str) // "%E6%B7%B1%E5%9C%B3%E5%8D%8E%E5%BC%BA"

    let ret = []

    for (let i = 0; i < str1.length / 3; i++) {
      ret.push(str1.slice(i * 3, (i + 1) * 3).slice(1))
    }

     // ret = ["E6", "B7", "B1", "E5", "9C", "B3", "E5", "8D", "8E", "E5", "BC", "BA"]

    return ret.map(el => parseInt(el, 16)) // [230, 183, 177, 229, 156, 179, 229, 141, 142, 229, 188, 186]
  }

utf-8转unicode

/**
* 
* @param arr {Array{Number}}
* @return {string}
*/
function decodeUTF8 (arr = [230, 183, 177, 229, 156, 179, 229, 141, 142, 229, 188, 186]) {
  let str = arr.reduce((prev, cur) => prev +=`%${cur.toString(16)}`, ‘‘)

  return decodeURIComponent(str) // ‘深圳华强‘
}

测试

> encodeUTF8()
< [230, 183, 177, 229, 156, 179, 229, 141, 142, 229, 188, 186]

> decodeUTF8()
< "深圳华强"

最后回到我们开头的问题, ‘\xe6\x88\x91\xe4\xbb\xac‘ 到底代表什么意思?

我尝试很很多种方法,发现只要js识别到 ‘\xe6\x88\x91\xe4\xbb\xac‘ 马上就进行解码了,根本没有机会操作。。。最后我发现将其中\要先转义处理:‘\xe6\x88\x91\xe4\xbb\xac‘,然后就好处理了,如果这个东西要前端要展示的话,只能暂时求助后端同学提前对反斜杠进行转移处理了。。。

let reg = /\\x/g
console.log(‘\\xe6\\x88\\x91\\xe4\\xbb\\xac‘) // \xe6\x88\x91\xe4\xbb\xac
console.log(‘\\xe6\\x88\\x91\\xe4\\xbb\\xac‘.replace(reg, ‘%‘)) // %e6%88%91%e4%bb%ac
console.log(decodeURIComponent(‘\\xe6\\x88\\x91\\xe4\\xbb\\xac‘.replace(reg, ‘%‘))) // 我们

参考资料:
UTF-8编码规则(转)
rfc3629
查看字符编码(UTF-8)在线工具
字符编码的前世今生
两次encodeURI和URLDecode的原理分析
JavaScript进行UTF-8编码与解码

JS中unicode和utf-8的转换

上一篇:js实现多张图片每隔一秒换一张图片


下一篇:node.js vue.js 安装