IE8中JSON.stringify方法对自动转换unicode字符的解决方案

IE8内置了JSON对象,用以处理JSON数据。与标准方法的不同,IE8的JSON.stringify会把utf-8字符转码:

    var str = "我是程序员"
    var jsonstr = JSON.stringify(str) //""\u6211\u662f\u7a0b\u5e8f\u5458""

一般情况下,我们是在向服务器发送数据的时候,才调用这个方法。服务器端可以正确的解析,所以没有什么问题。但是如果我们jsonstr还要在别的地方用到,那就需要做一些处理。

一种方法是使用eval:

    var parsed = eval(‘(‘+jsonstr+‘)‘) //"我是程序员"

但是,当我们对str调用了不止一次的话,这样的方法还行吗:

    var str = ‘我是程序员‘
    var jsonstr = JSON.stringify(str)
    var another_jsonstr = JSON.stringify(jsonstr) //
    var another_parsed = eval(‘(‘+another_jsonstr+‘)‘)
    another_parsed //""\u6211\u662f\u7a0b\u5e8f\u5458""

事实证明是不行的,那么我们写一个方法,如果发现解析的结果有utf-8码,就认为该字符串未解析完全,继续调用eval解析:

  function IE8parse(json) {
        var re = /\\u[0-9A-Fa-f]{4}/,
            result
        result = eval(‘(‘ + json + ‘)‘)
        while (re.test(result)) {
            result = eval(‘(‘ + result + ‘)‘)
        }
        return result
    }  IE8parse(another_jsonstr) //"我是程序员"

另一种方法是把IE8的JSON.stringify方法做一些处理,把它转化后的字符串中的utf-8码转化回字符:

    function stringify(object){
        var string = JSON.stringify(object)
        return string.replace(/\\u([0-9a-fA-F]{2,4})/g,function(string,matched){
            return String.fromCharCode(parseInt(matched,16))
        })
    }

这样,就可以解决掉IE8中JSON.stringify自动转换utf-8字符带来的不便了。

时间: 2024-07-30 03:42:51

IE8中JSON.stringify方法对自动转换unicode字符的解决方案的相关文章

JS中JSON.stringify()方法,将js对象转换成字符串,传入服务器

JSON 通常用于与服务端交换数据. 在向服务器发送数据时一般是字符串. 我们可以使用 JSON.stringify() 方法将 JavaScript 对象转换为字符串. 语法 JSON.stringify(value[, replacer[, space]]) 参数说明: value: 必需, 要转换的 JavaScript 值(通常为对象或数组). replacer: 可选.用于转换结果的函数或数组. 如果 replacer 为函数,则 JSON.stringify 将调用该函数,并传入每个

js中使用eval()方法将字符串转换成日期格式、并获取指定时间的日期

1.在js中eval()方法将字符串格式数据转换成日期格式 function getDate(strDate) {         //strDate为需要转换成日期格式的字符串         var date = eval('new Date(' + strDate.replace(/\d+(?=-[^-]+$)/,                 function (a) { return parseInt(a, 10) - 1; }).match(/\d+/g) + ')');    

浅谈 JSON.stringify 方法

用过 json 的应该都知道,把一个对象通过 stringify 之后提交给后台或者存储在 Storage 里是很常用的手段.但是 IE6-7 下没有 JSON 对象,所以要借助 json2.js 来实现. 今天我们来简单介绍下 stringify 方法的一些正确使用姿势吧.当然,让高手们贱笑了,本文只是分享一些方法给新手朋友们. var data = [ {name: "王尼玛", sex:1, age: 30}, {name: "王尼美", sex:0, age

JSON.parse()和JSON.stringify()方法学习

JSON.parse()和JSON.stringify()方法学习 JSON对象中有两个非常好用的方法 JSON.parse接受json字符串转化为JS对象 JSON.stringify接收一个JS对象转化为json字符串 JSON对象与普通对象的区别是JSON对象键值对都必须用双引号 例如: const my={ name:"dylan", age:"18" } let myObj=JSON.stringify(my) console.log(myObj)//&q

Js中JSON.stringify()与JSON.parse()与eval()详解及使用案例

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.因为采用独立于语言的文本格式,也使用了类似于C语言家族的习惯,拥有了这些特性使使JSON称为理想的数据交换语言,作用是易于阅读和编写,同时也易于机器解析和生成(一般用于网络传输速率). 一:JSON.parse(); 作用:将json字符串转换成json对象 语法:JSON. parse(text[,reviver]). 参数: text:必选,一个有效的json字符串. reviver:可选. 返回值:

JSON.stringify 方法

用过 json 的应该都知道,把一个对象通过 stringify 之后提交给后台或者存储在 Storage 里是很常用的手段.但是 IE6-7 下没有 JSON 对象,所以要借助 json2.js 来实现. 今天我们来简单介绍下 stringify 方法的一些正确使用姿势吧.当然,让高手们贱笑了,本文只是分享一些方法给新手朋友们. 文本运行 var data = [ {name: "王尼玛", sex:1, age: 30}, {name: "王尼美", sex:0

浅谈 JSON.stringify 方法【转】

但是 IE6-7 下没有 JSON 对象,所以要借助json2.js来实现. 今天我们来简单介绍下stringify方法的一些正确使用姿势吧. 当然,让高手们贱笑了,本文只是分享一些方法给新手朋友们. var data = [ {name: "王尼玛", sex:1, age: 30}, {name: "王尼美", sex:0, age: 20}, {name: "王大锤", sex:1, age: 30} ]; var str_json = J

js中json字符串与对象的转换及是否为空

1.json对象(数组)转字符串 var b=[ { "CategoryName" : "Beverages", "ProductName" : "Steeleye Stout", "Country" : "UK", "Price" : "1008.0000", "Quantity" : "65" }, {

js中json对象和字符串的转换

JSON.parse() : 字符串-->json对象 1 var str = '{"name":"huangxiaojian","age":"23"}'//单引号写在{}外,每个属性名都必须用双引号,否则会抛出异常. 2 JSON.parse(str) 3 结果: 4 Object 5 age: "23" 6 name: "huangxiaojian" 7 __proto__: