JS对象与json字符串相互转换实现方法示例


Posted in Javascript onJune 14, 2018

本文实例讲述了JS对象与json字符串相互转换实现方法。分享给大家供大家参考,具体如下:

今天在面试的时候,面试官问到js对象与json字符串的互转问题,由于自己平时在用的时候没有在意,而且在工作中由于用的较少,没有答上来,所以今天特地查查资料复习一下, 巩固一下这方面的知识。

1、js对象转换成json字符串

在与后端进行交互时,有时需要把js对象转换成json字符串格式,这时我们需要去引用一下json2.js这个文件,然后调用JSON.stringify()方法。例如:

var data = new Object();
var jsonData = JSON.stringify(data);

2、json字符串转换成js对象

在工作中在ajax获取后端数据时,获取到的是json格式,有时就需要我们转换成js对象格式。在这里我们使用jQuery的一个$.parseJSON()方法将JSON格式的数据转换成js对象格式。例如:

var jsonData = $.getJSON();
var data = $.parseJSON(jsonData);

当然,还可以使用JSON.parse()方法,方法同上,但是有的浏览器对JSON.parse()的支持不是很理想,所以在使用时尽量使用.parseJSON()方法。.parseJSON()方法在浏览器支持时会返回执行JSON.parse()方法的结果,否则会返回类似执行eval()方法的结果,具体参考jQuery1.9.1得出:

parseJSON: function( data ) {
 // Attempt to parse using the native JSON parser first
 if ( window.JSON && window.JSON.parse ) {
  return window.JSON.parse( data );
 }
 if ( data === null ) {
  return data;
 }
 if ( typeof data === "string" ) {
  // Make sure leading/trailing whitespace is removed (IE can't handle it)
  data = jQuery.trim( data );
  if ( data ) {
   // Make sure the incoming data is actual JSON
   // Logic borrowed from http://json.org/json2.js
   if ( rvalidchars.test( data.replace( rvalidescape, "@" )
    .replace( rvalidtokens, "]" )
    .replace( rvalidbraces, "")) ) {
    return ( new Function( "return " + data ) )();
   }
  }
 }
 jQuery.error( "Invalid JSON: " + data );
},

这样就完成了js对象与JSON字符串的互转了。

Javascript 相关文章推荐
jquery多浏览器捕捉回车事件代码
Jun 22 Javascript
Jqyery中同等与js中windows.onload的应用
May 10 Javascript
javascript Event对象详解及使用示例
Nov 22 Javascript
JavaScript模板引擎用法实例
Jul 10 Javascript
详解js数组的完全随机排列算法
Dec 16 Javascript
Vue中添加过渡效果的方法
Mar 16 Javascript
bootstrap日期控件问题(双日期、清空等问题解决)
Apr 19 Javascript
Vuex 在Vue 组件中获得Vuex 状态state的方法
Aug 27 Javascript
使用vue实现各类弹出框组件
Jul 03 Javascript
详解关闭令人抓狂的ESlint 语法检测配置方法
Oct 28 Javascript
vue列表数据发生变化指令没有更新问题及解决方法
Jan 16 Javascript
微信小程序实现多图上传
Jun 19 Javascript
微信小程序左滑动显示菜单功能的实现
Jun 14 #Javascript
vue中如何让子组件修改父组件数据
Jun 14 #Javascript
微信小程序分享功能之按钮button 边框隐藏和点击隐藏
Jun 14 #Javascript
MVVM框架下实现分页功能示例
Jun 14 #Javascript
jQuery实现下拉菜单动态添加数据点击滑出收起其他功能
Jun 14 #jQuery
React 组件间的通信示例
Jun 14 #Javascript
三分钟学会用ES7中的Async/Await进行异步编程
Jun 14 #Javascript
You might like
刚才在简化php的库,结果发现很多东西
2006/12/31 PHP
php中随机显示图片的函数代码
2011/06/23 PHP
详解PHP错误日志的获取方法
2015/07/20 PHP
使用xampp搭建运行php虚拟主机的详细步骤
2015/10/21 PHP
php插入含有特殊符号数据的处理方法
2016/11/24 PHP
php解析base64数据生成图片的方法
2016/12/06 PHP
PHP让网站移动访问更加友好方法
2019/02/14 PHP
深入理解JavaScript系列(12) 变量对象(Variable Object)
2012/01/16 Javascript
判断输入是否为空,获得输入类型的JS代码
2013/10/30 Javascript
JavaScript实现网页加载进度条代码超简单
2015/09/21 Javascript
使用jQuery的ajax方法向服务器发出get和post请求的方法
2017/01/13 Javascript
AngularJS遍历获取数组元素的方法示例
2017/11/11 Javascript
Angular移动端页面input无法输入的解决方法
2017/11/14 Javascript
深入理解 webpack 文件打包机制(小结)
2018/01/08 Javascript
vue2 mint-ui loadmore实现下拉刷新,上拉更多功能
2018/03/21 Javascript
使用IPython来操作Docker容器的入门指引
2015/04/08 Python
python简单的函数定义和用法实例
2015/05/07 Python
Python实现的字典值比较功能示例
2018/01/08 Python
Numpy的简单用法小结
2019/08/28 Python
Pytorch 计算误判率,计算准确率,计算召回率的例子
2020/01/18 Python
python实现二分类和多分类的ROC曲线教程
2020/06/15 Python
Python unittest基本使用方法代码实例
2020/06/29 Python
python Zmail模块简介与使用示例
2020/12/19 Python
Html5页面点击遮罩层背景关闭遮罩层
2020/11/30 HTML / CSS
受外贸欢迎的美国主机:BlueHost
2017/05/16 全球购物
北美个性化礼品商店:Things Remembered
2018/06/12 全球购物
linux面试题参考答案(9)
2016/01/29 面试题
高校毕业生自我鉴定
2013/10/27 职场文书
创业大赛策划书
2014/03/01 职场文书
新闻发布会主持词
2014/03/28 职场文书
民事诉讼授权委托书范文
2014/08/02 职场文书
2015年度招聘工作总结
2015/05/28 职场文书
秀!学妹看见都惊呆的Python小招数!【详细语言特性使用技巧】
2021/04/27 Python
JS Canvas接口和动画效果大全
2021/04/29 Javascript
Python提取PDF指定内容并生成新文件
2021/06/09 Python
nginx location 带斜杠【 / 】与不带的区别
2022/04/13 Servers