将后台程序(如php)发送过来的json数据转化为javascript的数组或者对象的方法十分简单,代码如下:

1 // 假设后台发送的json数据为 '{a:2,b:1}' 存储于str中
2 var data = eval( '(' + str + ')' );

然而想将一个javascript对象转化为json格式的字符串却并不那么简单,特别是对象的属性值递归包含一个对象时(如 var obj={a:[2,3],b:{m:[3,4],n:2} } ),那么有没有什么方法将obj转化为json格式的字符串呢?

当然你可以自己写一个函数,递归遍历一个对象并将其转化为json格式的字符串,对于大部分人来说这有些困难并容易出错。幸好已经有人做好了这件事情,你只用包含一段javascript代码即可。

json2.js

使用方法:

01 <!doctype html>
02 <html>
03 <body>
04 <script src="json2.js"></script>
05 <script>
06 var obj={a:[2,3],b:{m:[3,4],n:2} };
07 var jsonStr = JSON.stringify( obj );
08 alert(jsonStr);
09 //将显示 {"a":[2,3],"b":{"m":[3,4],"n":2}}
10 </script>
11 </body>
12 </html>

假如有两个变量,我要将a转换成字符串,将b转换成JSON对象:

1 var a={"name":"tom","sex":"男","age":"24"};
2 var b='{"name":"Mike","sex":"女","age":"29"}';

在Firefox,chrome,opera,safari,ie9,ie8等高级浏览器直接可以用JSON对象的stringify()和parse()方法。JSON.stringify(obj)将JSON转为字符串。JSON.parse(string)将字符串转为JSON格式;

上面的转换可以这么写:

1 var a={"name":"tom","sex":"男","age":"24"};
2 var b='{"name":"Mike","sex":"女","age":"29"}';
3 var aToStr=JSON.stringify(a);
4 var bToObj=JSON.parse(b);
5 alert(typeof(aToStr));  //string
6 alert(typeof(bToObj));  //object

JSON.stringify()

ie8(兼容模式),ie7和ie6没有JSON对象,不过http://www.json.org/提供了一个json.js,这样ie8(兼容模式),ie7和ie6就可以支持JSON对象以及其stringify()和parse()方法;你可以在https://github.com/douglascrockford/JSON-js上获取到这个js,一般现在用json2.js。ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象:

1 var c='{"name":"Mike","sex":"女","age":"29"}';
2 var cToObj=eval("("+c+")");
3 alert(typeof(cToObj));

jQuery中也有将字符串转为JSON格式的方法jQuery.parseJSON( json ),接受一个标准格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)对象。当然如果有兴趣可以自己封装一个jQuery扩展,jQuery.stringifyJSON(obj)将JSON转为字符串。

JSON.stringify(jsonobj),本来是最简便的方法,可是存在浏览器兼容问题(仅适用于IE8+,Chrome 1+,FF 3+)。下面再介绍一个方法:

01 var O2String = function (O) {
02     //return JSON.stringify(jsonobj);
03  
04     var S = [];
05     var J = "";
06     if (Object.prototype.toString.apply(O) === '[object Array]') {
07         for (var i = 0; i < O.length; i++)
08             S.push(O2String(O[i]));
09         J = '[' + S.join(',') + ']';
10     }
11     else if (Object.prototype.toString.apply(O) === '[object Date]') {
12         J = "new Date(" + O.getTime() + ")";
13     }
14     else if (Object.prototype.toString.apply(O) === '[object RegExp]' || Object.prototype.toString.apply(O) === '[object Function]') {
15         J = O.toString();
16     }
17     else if (Object.prototype.toString.apply(O) === '[object Object]') {
18         for (var in O) {
19             O[i] = typeof (O[i]) == 'string' '"' + O[i] + '"' : (typeof(O[i]) === 'object' ? O2String(O[i]) : O[i]);
20             S.push(i + ':' + O[i]);
21         }
22         J = '{' + S.join(',') + '}';
23     }
24  
25     return J;
26 };

使用方法也很简单:

01 var jsonStr = O2String(
02     [
03         {
04             "Page""plan",
05             "Custom":
06             [
07                 {
08                     "ItemName""CustomLabel1",
09                     "ItemContent": 1,
10                     "IsItem"true,
11                     "ItemDate"new Date(1320774905467),
12                     "ItemReg": /[\w]*?/gi,
13                     "ItemFunc"function () { alert("ItemFunc"); }
14                 },
15                 {
16                     "ItemName""CustomLabel1",
17                     "ItemContent": 1,
18                     "IsItem"true,
19                     "ItemDate"new Date(1320774905467),
20                     "ItemReg": /[\w]*?/gi,
21                     "ItemFunc"function () { alert("ItemFunc"); }
22                 }
23             ]
24         },
25         {
26             "Page""project",
27             "Custom":
28             [
29                 {
30                     "ItemName""CustomLabel2",
31                     "ItemContent": 2,
32                     "IsItem"false,
33                     "ItemDate"new Date(1320774905467),
34                     "ItemReg": /[\w]*?/gi,
35                     "ItemFunc"function () { alert("ItemFunc"); }
36                 },
37                 {
38                     "ItemName""CustomLabel2",
39                     "ItemContent": 2,
40                     "IsItem"false,
41                     "ItemDate"new Date(1320774905467),
42                     "ItemReg": /[\w]*?/gi,
43                     "ItemFunc"function () { alert("ItemFunc"); }
44                 }
45             ]
46         }
47     ]
48 );
49 alert(jsonStr);
50 var jsonObj = eval("(" + jsonStr + ")");
51 alert(jsonObj.length);

如何将javascript对象转换成字符串的更多相关文章

  1. 前台 JSON对象转换成字符串 相互转换 的几种方式

    在最近的工作中,使用到JSON进行数据的传递,特别是从前端传递到后台,前台可以直接采用ajax的data函数,按json格式传递,后台Request即可,但有的时候,需要传递多个参数,后台使用requ ...

  2. json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值

    一.json相关概念 json,全称为javascript object notation,是一种轻量级的数据交互格式.采用完全独立于语言的文本格式,是一种理想的数据交换格式. 同时,json是jav ...

  3. JSON对象转换成字符串【JSON2.JS】

    下载地址 https://github.com/douglascrockford/JSON-js JSON.JS和JSON2.JS的区别 JSON.JS使用的方法名称不同,用的是toJSONStrin ...

  4. vue中如何将时间对象转换成字符串

    借鉴element-admin中封装好的方法 import { parseTime } from '@/utils'// 在utils目录下的index.js文件中,方法如下 /** * Parse ...

  5. JSON对象转换成JSON字符串

    1.问题背景 有一个json对象,需要将其转换成json字符串 JSON.stringify(obj) 2.实现源码 <!DOCTYPE html PUBLIC "-//W3C//DT ...

  6. a标签下载;页面传参row对象先转换成字符串。

    jsp:添加一列 <th data-options="field:'id',width:180,formatter: rowformater" width="20% ...

  7. Razor 将C#对象转换成Javascript对象, json还原被转码的字符 &quot·· HTML转义符

    Razor 将C#对象转换成Javascript对象 在Razor中使用Json字符串,特殊字符被自动转义(如:\"->") @{ var jsonStr = Html.Ra ...

  8. Newtonsoft.Json 把对象转换成json字符串

    var resultJson = new { records = rowCount, page = pageindex, //总页数=(总页数+页大小-1)/页大小 total = (rowCount ...

  9. json 字符串转换成对象,对象转换成json字符串

    json   字符串转换成对象,对象转换成json字符串 前端: 方法一: parseJSON方法:   [注意jquery版本问题] var str = '{"name":&qu ...

随机推荐

  1. Python简要标准库(1)

    sys sys这个模块让你能够访问与Python解释器联系紧密的变量和函数 其中的一些在下表 F argv 命令行参数,包括脚本名称 exit([arg]) 退出当前的程序,可选参数为给定的返回值或者 ...

  2. vim python自动补全插件:pydiction

    vim python自动补全插件:pydiction 可以实现下面python代码的自动补全: 1.简单python关键词补全 2.python 函数补全带括号 3.python 模块补全 4.pyt ...

  3. 孤荷凌寒自学python第七十七天开始写Python的第一个爬虫7

    孤荷凌寒自学python第七十七天开始写Python的第一个爬虫7 (完整学习过程屏幕记录视频地址在文末) 今天在上一天的基础上继续完成对我的第一个代码程序的书写. 今天的学习仍然是在纯粹对docx模 ...

  4. Dreamweaver CS5网页制作教程

    说到Dreamweaver这个网页制作神器,不由得想起在学校里上的选修课,那是的我们只知道 table 布局,只知道构建网站最方便的是使用“所见即所得”编辑器.回忆一下,真的是很怀旧啊! 虽说咱现在大 ...

  5. block inline 和 inline-block

    概念 block和inline这两个概念是简略的说法,完整确切的说应该是 block-level elements (块级元素) 和 inline elements (内联元素). block元素通常 ...

  6. 【shell 练习4】编写Shell用户管理脚本(二)

    一.创建.删除.查看用户,随机生成八位数密码 #!/bin/bash #Author:yanglt #!/bin/bash #Author:yanglt #Blog:https://www.cnblo ...

  7. 深度学习图像分割——U-net网络

    写在前面: 一直没有整理的习惯,导致很多东西会有所遗忘,遗漏.借着这个机会,养成一个习惯. 对现有东西做一个整理.记录,对新事物去探索.分享. 因此博客主要内容为我做过的,所学的整理记录以及新的算法. ...

  8. LeetCode - 326, 342, 231 Power of Three, Four, and Two

    1. 问题 231. Power of Two: 判断一个整数是否是2的n次方,其中n是非负整数 342. Power of Four: 判断一个整数是否是4的n次方,其中n是非负整数 326. Po ...

  9. Django基本目录详解

    1.app是自己建立的一个存放app的文件夹,因为项目大了之后会存在很多app(pycharm生成app方法 Tools-Run manage.py Task-输入startapp app名称) 2. ...

  10. hadoop问题集(1)

        参考: http://dataunion.org/22887.html 1.mapreduce_shuffle does not exist 执行任何时报错: Container launch ...