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 相关文章推荐
JS 日期验证正则附asp日期格式化函数
Sep 11 Javascript
firefox插件Firebug的使用教程
Jan 02 Javascript
jQuery调用AJAX时Get和post公用的乱码解决方法实例说明
Jun 04 Javascript
JQuery 文本框回车跳到下一个文本框示例代码
Aug 30 Javascript
Jqgrid设置全选(选择)及获取选择行的值示例代码
Dec 28 Javascript
关于javaScript注册click事件传递参数的不成功问题
Jul 18 Javascript
值得分享的JavaScript实现图片轮播组件
Nov 21 Javascript
Reactjs实现通用分页组件的实例代码
Jan 19 Javascript
深入理解vue-loader如何使用
Jun 06 Javascript
JS实现websocket长轮询实时消息提示的效果
Oct 10 Javascript
vue click.stop阻止点击事件继续传播的方法
Sep 04 Javascript
vue在响应头response中获取自定义headers操作
Jul 24 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比较多维数组中值的大小排序实现代码
2012/09/08 PHP
php生成RSS订阅的方法
2015/02/13 PHP
PHP+jQuery翻板抽奖功能实现
2015/10/19 PHP
PHP常见漏洞攻击分析
2016/02/21 PHP
Yii的Srbac插件用法详解
2016/07/14 PHP
js操作ajax返回的json的注意问题!
2010/02/23 Javascript
限制文本框输入N个字符的js代码
2010/05/13 Javascript
js 关于=+与+=日期函数使用说明(赋值运算符)
2011/11/15 Javascript
setTimeout自动触发一个js的方法
2014/01/15 Javascript
jQuery Mobile中的button按钮组件基础使用教程
2016/05/23 Javascript
JS控制HTML元素的显示和隐藏的两种方法
2016/09/27 Javascript
通过命令行创建vue项目的方法
2017/07/20 Javascript
angular-tree-component的使用详解
2018/07/30 Javascript
vue+mousemove实现鼠标拖动功能(拖动过快失效问题解决方法)
2018/08/24 Javascript
vue-router 实现导航守卫(路由卫士)的实例代码
2018/09/02 Javascript
详谈js的变量提升以及使用方法
2018/10/06 Javascript
vue-cli3.0 脚手架搭建项目的过程详解
2018/10/19 Javascript
详解如何使用node.js的开发框架express创建一个web应用
2018/12/20 Javascript
优化Vue中date format的性能详解
2020/01/13 Javascript
nodejs+koa2 实现模仿springMVC框架
2020/10/21 NodeJs
python中 ? : 三元表达式的使用介绍
2013/10/09 Python
python实现探测socket和web服务示例
2014/03/28 Python
在Python 3中实现类型检查器的简单方法
2015/07/03 Python
Python 获取当前所在目录的方法详解
2017/08/02 Python
python实现猜单词小游戏
2020/05/22 Python
Python在for循环中更改list值的方法【推荐】
2018/08/17 Python
Python绘制的二项分布概率图示例
2018/08/22 Python
基于PyQt4和PySide实现输入对话框效果
2019/02/27 Python
python set内置函数的具体使用
2019/07/02 Python
详解HTML5 Canvas绘制不规则图形时的非零环绕原则
2016/03/21 HTML / CSS
自动化系在校本科生求职信
2013/10/23 职场文书
求职信模板怎么做
2014/01/26 职场文书
市场开发计划书
2014/05/07 职场文书
大学生个人求职信例文
2014/07/07 职场文书
2015年小学开学寄语
2015/02/27 职场文书
HTML中的表单Form实现居中效果
2021/05/25 HTML / CSS