解决JSON.stringify()自动将中文转译成unicode的方法

Posted 格子熊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决JSON.stringify()自动将中文转译成unicode的方法相关的知识,希望对你有一定的参考价值。

  最近在工作中,发现在IE8下JSON.stringify()自动将中文转译为unicode编码,原本选择的中文字符,传到后台变为了unicode编码,即\u****的形式。查找资料后发现,与标准的JSON.stringify()不同,IE8内置的JSON.stringify()会自动将编码从utf-8转为unicode编码,导致出现这种类似于乱码的情况。

  解决方法分为两种,第一种是后台接收到数据之后,将该数据再进行一次转码,重新转为utf-8,然后再保存到数据库中,这样,再次从数据库取出传给前端的数据将变成utf-8格式(即正常的中文)。第二种则是不管在IE8下还是高级浏览器中,使用eval()统一进行转码,最后的结果都为utf-8编码。

  本文主要讲解第二种方法,即使用eval()转码的方法。在MDN上,eval()的解释是:eval()的参数是一个字符串。如果字符串表示的是表达式,eval()会对表达式进行求值。如果参数表示一个或多个javascript语句, 那么eval()就会执行这些语句。

var a = "吃翔翔";
var unicodeJsonA = JSON.stringify("a");  //unicode
var jsonA = eval(‘(‘ + unicodeJsonA + ‘)‘);  //utf-8

  如上代码,通过eval()执行,强行将unicode转码为utf-8,无论JSON.stringify()后出来的结果是utf-8还是unicode,统一转为utf-8格式。

  其实,解决的方法还有第三种——使用json2.js中的JSON.stringify()代替IE8的JSON.stingify()。但是,当有浏览器自带的JSON对象时,会启用浏览器自带的JSON对象代替json2.js中的JSON对象。为了解决这个问题,可以将json2.js中的JSON对象改为JSON2对象,即将JSON.stringify()改为JSON2.stringify()。

  以上几种方法皆可解决IE8下自动将中文转译为unicode的问题。

以上是关于解决JSON.stringify()自动将中文转译成unicode的方法的主要内容,如果未能解决你的问题,请参考以下文章

Vue - 路由传一个Object参数,刷新页面后数据变成“[Object Object]“ 解决方案

JSON.stringify自动求和数

(转)JS之——解决IE678使用JSON.stringify报JSON未定义错误的问题

JSON.stringify() :

jQuery解决IE6、7、8不能使用 JSON.stringify 函数的问题

JS JSON.stringify 详解