首页>web前端>javascript 特效

JSON对象和字符串之间相互转换JSON.parse() 和 JSON.stringify()的高级用法、方法、区别和不同之处

2018-09-02 08:51:25 | 查看次数 176 | 分类: web前端>javascript 特效 文章来源:来源:http://www.ifx666.cn

摘要内容:JSON.parse() 和 JSON.stringify() 的高级用法,可以将返回值过滤,转换等

所有现代浏览器都支持 JSON 对象,有两个非常有用的方法来处理 JSON 格式的内容:

  • JSON.parse(string) :接受一个 JSON 字符串并将其转换成一个 JavaScript 对象。
  • JSON.stringify(obj) :接受一个 JavaScript 对象并将其转换为一个 JSON 字符串。

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

js 代码:
  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格式;

上面的转换可以这么写:

js 代码:
  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. console.log(typeof(aToStr));  //string
  6. console.log(typeof(bToObj));//object

尽管这些方法通常用在对象上,但它们也可以在数组上使用:

JavaScript 代码:
  1. const myArr = ['bacon', 'letuce', 'tomatoes'];
  2. const myArrStr = JSON.stringify(myArr);
  3. console.log(myArrStr);
  4. // "["bacon","letuce","tomatoes"]"
  5. console.log(JSON.parse(myArrStr));
  6. // ["bacon","letuce","tomatoes"]

ie8(兼容模式),ie7和ie6可以使用eval()将字符串转为JSON对象,

js 代码:
  1. var c='{"name":"Mike","sex":"女","age":"29"}';
  2. var cToObj=eval("("+c+")");
  3. console.log(typeof(cToObj));

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

JSON.parse() 和 JSON.stringify() 的高级用法,可以将返回值过滤,转换等。

上一篇: jquery专区视频基础教程

下一篇: 锋利的jQuery读者可以系统地掌握jQuery的选择器、DOM操作等操作细节

验证码:
评论列表
  • 文章推荐

    09-19 | 查看次数 786

    《深入理解Spring Cloud与微服务构建》PDF下载

    09-14 | 查看次数 197

    bootstrap tooltip 提示框的样式、提示字体颜...

    09-01 | 查看次数 200

    json字符串与java对象互转,json字符串转化为map...

    08-04 | 查看次数 383

    java面试题及答案---2018核心Java面试问题与解答...

    08-03 | 查看次数 900

    java面试题及答案---2018核心Java面试问题与解答...

    最新评论
    文章标题:管理和发布文章java cms

    评论内容:能下载吗

    评论时间:2018-12-12 01:30:02

  • 返回顶部
    欢迎投稿
    返回底部