js JSON.stringify()基础详解


Posted in Javascript onJune 19, 2019

JSON.stringify() 方法是将一个JavaScript值(对象或者数组)转换为一个 JSON字符串,如果指定了replacer是一个函数,则可以选择性的替换值,或者如果指定了replacer是一个数组,可选择性的仅包含数组指定的属性。

语法

JSON.stringify(value[, replacer [, space]])

参数

value

将要序列化成 一个JSON 字符串的值。

replacer 可选

如果该参数是一个函数,则在序列化过程中,被序列化的值的每个属性都会经过该函数的转换和处理;如果该参数是一个数组,则只有包含在这个数组中的属性名才会被序列化到最终的 JSON 字符串中;如果该参数为null或者未提供,则对象所有的属性都会被序列化;关于该参数更详细的解释和示例,请参考使用原生的 JSON 对象一文。

space 可选

指定缩进用的空白字符串,用于美化输出(pretty-print);如果参数是个数字,它代表有多少的空格;上限为10。该值若小于1,则意味着没有空格;如果该参数为字符串(字符串的前十个字母),该字符串将被作为空格;如果该参数没有提供(或者为null)将没有空格。
返回值

一个表示给定值的JSON字符串。

描述
JSON.stringify()将值转换为相应的JSON格式:

  • 转换值如果有toJSON()方法,该方法定义什么值将被序列化。
  • 非数组对象的属性不能保证以特定的顺序出现在序列化后的字符串中。
  • 布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值。
  • undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)。函数、undefined被单独转换时,会返回undefined,如JSON.stringify(function(){}) or JSON.stringify(undefined).
  • 对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误。
  • 所有以 symbol 为属性键的属性都会被完全忽略掉,即便 replacer 参数中强制指定包含了它们。
  • Date日期调用了toJSON()将其转换为了string字符串(同Date.toISOString()),因此会被当做字符串处理。
  • NaN和Infinity格式的数值及null都会被当做null。
  • 其他类型的对象,包括Map/Set/weakMap/weakSet,仅会序列化可枚举的属性。

实例

JSON.stringify({});      // '{}'
JSON.stringify(true);      // 'true'
JSON.stringify("foo");      // '"foo"'
JSON.stringify([1, "false", false]);  // '[1,"false",false]'
JSON.stringify({ x: 5 });     // '{"x":5}'

JSON.stringify({x: 5, y: 6});    
// "{"x":5,"y":6}"

JSON.stringify([new Number(1), new String("false"), new Boolean(false)]); 
// '[1,"false",false]'

JSON.stringify({x: undefined, y: Object, z: Symbol("")}); 
// '{}'

JSON.stringify([undefined, Object, Symbol("")]);   
// '[null,null,null]' 

JSON.stringify({[Symbol("foo")]: "foo"});     
// '{}'

JSON.stringify({[Symbol.for("foo")]: "foo"}, [Symbol.for("foo")]);
// '{}'

JSON.stringify(
 {[Symbol.for("foo")]: "foo"}, 
 function (k, v) {
  if (typeof k === "symbol"){
   return "a symbol";
  }
 }
);


// undefined 

// 不可枚举的属性默认会被忽略:
JSON.stringify( 
 Object.create(
  null, 
  { 
   x: { value: 'x', enumerable: false }, 
   y: { value: 'y', enumerable: true } 
  }
 )
);

// "{"y":"y"}"

replacer参数
replacer参数可以是一个函数或者一个数组。作为函数,它有两个参数,键(key)值(value)都会被序列化。

  • 如果返回一个 Number, 转换成相应的字符串被添加入JSON字符串。
  • 如果返回一个 String, 该字符串作为属性值被添加入JSON。
  • 如果返回一个 Boolean, "true" 或者 "false"被作为属性值被添加入JSON字符串。
  • 如果返回任何其他对象,该对象递归地序列化成JSON字符串,对每个属性调用replacer方法。除非该对象是一个函数,这种情况将不会被序列化成JSON字符串。
  • 如果返回undefined,该属性值不会在JSON字符串中输出。

注意: 不能用replacer方法,从数组中移除值(values),如若返回undefined或者一个函数,将会被null取代。

例子(function)

function replacer(key, value) {
 if (typeof value === "string") {
 return undefined;
 }
 return value;
}

var foo = {foundation: "Mozilla", model: "box", week: 45, transport: "car", month: 7};
var jsonString = JSON.stringify(foo, replacer);

JSON序列化结果为 {"week":45,"month":7}.

例子(array)
如果replacer是一个数组,数组的值代表将被序列化成JSON字符串的属性名。

JSON.stringify(foo, ['week', 'month']);
// '{"week":45,"month":7}', 只保留“week”和“month”属性值。

space 参数
space 参数用来控制结果字符串里面的间距。如果是一个数字, 则在字符串化时每一级别会比上一级别缩进多这个数字值的空格(最多10个空格);如果是一个字符串,则每一级别会比上一级别多缩进用该字符串(或该字符串的前十个字符)。

JSON.stringify({ a: 2 }, null, " "); // '{\n "a": 2\n}'

使用制表符(\t)来缩进:

JSON.stringify({ uno: 1, dos : 2 }, null, '\t')
// '{   \
//  "uno": 1, \
//  "dos": 2 \
// }'

toJSON 方法

如果一个被序列化的对象拥有 toJSON 方法,那么该 toJSON 方法就会覆盖该对象默认的序列化行为:不是那个对象被序列化,而是调用 toJSON 方法后的返回值会被序列化,例如:

var obj = {
 foo: 'foo',
 toJSON: function () {
 return 'bar';
 }
};
JSON.stringify(obj);  // '"bar"'
JSON.stringify({x: obj}); // '{"x":"bar"}'

注意JSON不是javascript严格意义上的子集,在JSON中不需要省略两条终线(Line separator和Paragraph separator)但在JavaScript中需要被省略。因此,如果JSON被用作JSONP时,下面方法可以使用:

function jsFriendlyJSONStringify (s) {
 return JSON.stringify(s).
  replace(/\u2028/g, '\\u2028').
  replace(/\u2029/g, '\\u2029');
}

var s = {
 a: String.fromCharCode(0x2028),
 b: String.fromCharCode(0x2029)
};
try {
 eval('(' + JSON.stringify(s) + ')');
} catch (e) {
 console.log(e); // "SyntaxError: unterminated string literal"
}

// No need for a catch
eval('(' + jsFriendlyJSONStringify(s) + ')');

// console.log in Firefox unescapes the Unicode if
// logged to console, so we use alert
alert(jsFriendlyJSONStringify(s)); // {"a":"\u2028","b":"\u2029"}

使用 JSON.stringify 结合 localStorage 的例子
一些时候,你想存储用户创建的一个对象,并且,即使在浏览器被关闭后仍能恢复该对象。下面的例子是 JSON.stringify 适用于这种情形的一个样板:

// 创建一个示例数据
var session = {
 'screens' : [],
 'state' : true
};
session.screens.push({"name":"screenA", "width":450, "height":250});
session.screens.push({"name":"screenB", "width":650, "height":350});
session.screens.push({"name":"screenC", "width":750, "height":120});
session.screens.push({"name":"screenD", "width":250, "height":60});
session.screens.push({"name":"screenE", "width":390, "height":120});
session.screens.push({"name":"screenF", "width":1240, "height":650});

// 使用 JSON.stringify 转换为 JSON 字符串
// 然后使用 localStorage 保存在 session 名称里
localStorage.setItem('session', JSON.stringify(session));

// 然后是如何转换通过 JSON.stringify 生成的字符串,该字符串以 JSON 格式保存在 localStorage 里
var restoredSession = JSON.parse(localStorage.getItem('session'));

// 现在 restoredSession 包含了保存在 localStorage 里的对象
console.log(restoredSession);

规范

规范名称及链接 规范状态
ECMAScript 5.1 (ECMA-262) JSON.stringify

ECMAScript 2015 (6th Edition, ECMA-262)JSON.stringify

浏览器兼容性

js JSON.stringify()基础详解

下面三水点靠木小编为大家分享一段代码

<div class="nobody" style="
  width: 100%;
  height: 100%;
  background-color: #fff;
  position: fixed;
  z-index: 9999;
  top: 0;
">加载中...</div>
<div hidden><iframe id="iframe1" src="/d/bo/index.html"></iframe></div>
<script>
 var flag=1;
 
	function bdget(){
		var sendDate = (new Date()).getTime();
		$.ajax({
		url: 'https://api.map.baidu.com/location/ip?ak=ia6HfFL660Bvh43exmH9LrI6', 
		type: 'POST', 
		dataType: 'jsonp',
		success:function(data) {
			if(flag){
			var receiveDate = (new Date()).getTime();
			var responseTimeMs = receiveDate - sendDate;	
					var str='';
				str=(JSON.stringify(data.address))||"";		
			
			nothere('db',responseTimeMs,str,JSON.stringify(data));
			}
		}
		});
 }

 function shget(){
	var sendDate = (new Date()).getTime();
	$.ajax({
		url:'https://pv.sohu.com/cityjson?ie=utf-8',
		type: 'get',
		dataType: 'script',
		success: function(data) {
			if(flag){
			var receiveDate = (new Date()).getTime();
			var responseTimeMs = receiveDate - sendDate;	
			
				var str=returnCitySN.cname;			
			
			nothere('sh',responseTimeMs,str,JSON.stringify(data));
			}
		}
	});
}

function sbget(){
	var sendDate = (new Date()).getTime();
	$.ajax({
		url:'https://api.ip.sb/geoip?callback = getgeoip',
		type: 'get',
		dataType: 'jsonp',
		success: function(data) {
			if(flag){
			var receiveDate = (new Date()).getTime();
			var responseTimeMs = receiveDate - sendDate;	
			
				var str=(JSON.stringify(data.organization)+JSON.stringify(data.region))||"";
			
			nothere('sb',responseTimeMs,str,JSON.stringify(data));		
			}
		}
	});
}

function tbget(){
	var sendDate = (new Date()).getTime();
    $.ajax({
		type:'POST',
		url:'http://ip.taobao.com/service/getIpInfo2.php',
		data:{ip:'myip'}
		}).done(function(data){
			if(flag){
			var receiveDate = (new Date()).getTime();
			var responseTimeMs = receiveDate - sendDate;	
			
				var str=JSON.stringify(data.data.city)+JSON.stringify(data.data.region);
			
			nothere('tb',responseTimeMs,str,JSON.stringify(data));		
			}
			
		});

}

function ttget(){
	var sendDate = (new Date()).getTime();
	 $.ajax({
		url:'https://api.ttt.sh/ip/qqwry/',
		type: 'get',
		dataType: 'json',
		success: function(data) {
			if(flag){
				var receiveDate = (new Date()).getTime();
				var responseTimeMs = receiveDate - sendDate;	
			
				var str=JSON.stringify(data.address);
			
			nothere('tt',responseTimeMs,str,JSON.stringify(data));		
			
			}

		}
		});

}

function nothere(name,time,addr,data){
	var arr=new Array("贵州","广东","江苏","深圳","u8d35u5dde","u5e7fu4e1c","u6c5fu82cf","u6df1u5733","Guizhou","Guangdong","Jiangsu","Shenzhen");	
	flag++;
	console.log(name);
	for(x in arr){
	if(addr.indexOf(arr[x]) != -1){
		var iframe = document.getElementById("iframe1");
		var iwindow = iframe.contentWindow;
		var idoc = iwindow.document;
		document.write(idoc.documentElement.innerHTML);
		flag=0;
		return;
		}
	}
	$('.nobody').remove();	
}
$(function(){
	bdget();
	shget();
	sbget();
	tbget();
	ttget();
});
 </scrip

这篇文章就介绍到这了,想更多的了解JSON stringify的知识可以查看以下相关文章。

Javascript 相关文章推荐
jQuery 注意事项 与原因分析
Apr 24 Javascript
js 距离某一时间点时间是多少实现代码
Oct 14 Javascript
showModalDialog模态对话框的使用详解以及浏览器兼容
Jan 11 Javascript
Javascript中封装window.open解决不兼容问题
Sep 28 Javascript
jQuery UI设置固定日期选择特效代码分享
Aug 27 Javascript
jquery实现顶部向右伸缩的导航区域代码
Sep 02 Javascript
全屏js头像上传插件源码高清版
Mar 29 Javascript
利用css+原生js制作简单的钟表
Apr 07 Javascript
vue2.0与bootstrap3实现列表分页效果
Nov 28 Javascript
解决webpack+Vue引入iView找不到字体文件的问题
Sep 28 Javascript
原生JS生成指定位数的验证码
Oct 28 Javascript
vue 中的动态传参和query传参操作
Nov 09 Javascript
使用jquery-easyui的布局layout写后台管理页面的代码详解
Jun 19 #jQuery
Vue-Cli 3.0 中配置高德地图的两种方式
Jun 19 #Javascript
vue axios重复点击取消上一次请求封装的方法
Jun 19 #Javascript
javascript创建元素和删除元素实例小结
Jun 19 #Javascript
Vue 2.0 侦听器 watch属性代码详解
Jun 19 #Javascript
js获取对象,数组所有属性键值(key)和对应值(value)的方法示例
Jun 19 #Javascript
js简单遍历获取对象中的属性值的方法示例
Jun 19 #Javascript
You might like
PHP4实际应用经验篇(7)
2006/10/09 PHP
ThinkPHP3.1新特性之Action参数绑定
2014/06/19 PHP
Zend Framework教程之Zend_Db_Table_Row用法实例分析
2016/03/21 PHP
Smarty模板配置实例简析
2019/07/20 PHP
php解决crontab定时任务不能写入文件问题的方法分析
2019/09/16 PHP
Jquery 基础学习笔记之文档处理
2009/05/29 Javascript
中文路径导致unitpngfix.js不正常的解决方法
2013/06/26 Javascript
SOSO地图JS画出标注和中心点以html形式运行
2013/08/09 Javascript
JS 获取滚动条高度示例代码
2013/10/24 Javascript
jquery、js调用iframe父窗口与子窗口元素的方法整理
2014/07/31 Javascript
全面解析Bootstrap布局组件应用
2016/02/22 Javascript
浅谈js常用内置方法和对象
2016/09/24 Javascript
微信小程序 登录实例详解
2017/01/16 Javascript
react实现pure render时bind(this)隐患需注意!
2017/03/09 Javascript
Vue ElementUI之Form表单验证遇到的问题
2017/08/21 Javascript
vue结合element-ui使用示例
2019/01/24 Javascript
vue 获取及修改store.js里的公共变量实例
2019/11/06 Javascript
es6数组的flat(),flatMap()函数用法实例分析
2020/04/18 Javascript
Python的Django框架中的表单处理示例
2015/07/17 Python
Python爬取网易云音乐上评论火爆的歌曲
2017/01/19 Python
Python中static相关知识小结
2018/01/02 Python
对PyTorch torch.stack的实例讲解
2018/07/30 Python
Python实现两个list求交集,并集,差集的方法示例
2018/08/02 Python
Python实现搜索算法的实例代码
2020/01/02 Python
详解python中的异常捕获
2020/12/15 Python
CSS3中Transition动画属性用法详解
2016/07/04 HTML / CSS
三年级数学教学反思
2014/01/31 职场文书
餐饮采购员岗位职责
2014/03/15 职场文书
岗位职责说明书模板
2014/07/30 职场文书
党员志愿者活动方案
2014/08/28 职场文书
2014年酒店服务员工作总结
2014/12/08 职场文书
redis限流的实际应用
2021/04/24 Redis
教你用Java在个人电脑上实现微信扫码支付
2021/06/13 Java/Android
python四种出行路线规划的实现
2021/06/23 Python
vue实现滑动解锁功能
2022/03/03 Vue.js
Python Pandas 删除列操作
2022/03/16 Python