“简单form表单全代码”引发JSON.stringify()问题

摘要:
JSON。stringify()语法JSON Stringifyvalue将被序列化为JSON字符串值。替换器可以是数组或函数。如果它是一个数组,则只有数组中包含的属性名称将被序列化为最终的JSON字符串。如果是函数,则替换符将用作键值。如果它是一个函数,则每个序列化对象都将被传输到处理方法。Space可以选择指定一个空白字符串进行缩进。如果省略,则显示的值将没有分隔符。如果只是一个字符串,可以将这些字符串附加到输出值的每一行。

JSON.stringify()

语法

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

value

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

replacer 可选

       可以为数组或函数

       如果为数组:则只有包含在这个数组中的属性名才会被序列化到最终的 JSON 字符串中,replacer作key值(这个在讲实例的时候就知道这个key是干嘛的了,先记住就好)

        如果为函数:则把系列化后的每一个对象(记住是每一个)传进方法里面进行处理.

space 可选

        指定缩进用的空白字符串

        如果省略的话,那么显示出来的值就没有分隔符。直接输出来

        如果是一个数字的话,那么它就定义缩进几个字符,范围是:0到10(数字小于1,则默认为0,大于10,则默认为10)

        如果是一些转义字符,比如“ ”,表示回车,那么它每行一个回车。

        如果仅仅是字符串,就在每行输出值的时候把这些字符串附加上去就OK。当然,最大长度也是10个字符

实例说明

注意:以下的输出结果都是string类型的,为了容易看就没有用单引号‘’表明是字符串类型

只有一个参数

参数为对象:

var students = new Array();

students[0] = "pika";

students[1] = "hello";

students[2] = "hey";

var json = JSON.stringify(students);

alert(json);

输出结果:["pika","hello","hey"]

如果不用JSON.stringify()函数,直接alert(students),那么

输出结果:pika,hello,hey

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

从这些例子中可以看出:undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)

例子

JSON.stringify(

    Object.create(

        null,

        {

            x: { value: 'x', enumerable: false },

            y: { value: 'y', enumerable: true }

        }

    )

);

从例子中可以看出:不可枚举的属性会被忽略

有两个参数,第二个参数为函数
函数例子:

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

可以看出有一个key值,一个value值,还记得一开始说的第二个参数作key值吗?

实例:

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);
//输出结果:{"week":45,"month":7}

就是把第一个值传去函数进行相关的处理

有两个参数,第二个参数为数组
第一个参数为数组
var students = new Array();
students[0] = "pika";
students[1] = "hello";
students[2] = "hey";
var stu= new Array();
stu[0] = "how";
stu[1] = "are";
stu[2] = "u";
var json = JSON.stringify(students,stu);
alert(json);
//输出结果:["pika","hello","hey"]
结果是只有第一个值序列化了,第二个被忽略了

第一个参数为对象
var students = new Object();
students.name = "pika";
students.age = 19;
students.qq = "12345678";
var stu= new Array();
stu[0] = "name";
stu[1] = "qq";
var json = JSON.stringify(students,stu);
alert(json);
//输出结果:{"name":"pika","qq":"12345678"}
数组的值代表将被序列化成JSON字符串的属性名
stu数组没有“age”,所以students对象的“age”属性没有显示

有三个参数
前面说到第三个参数就是用来缩进或者直接添加字符串在序列化对象的前面,所以直接看例子就行啦,注意最多只能10个缩进或字符

JSON.stringify({ a: 2 }, null, " ");
// 输出结果:{ "a": 2 }

JSON.stringify({ uno: 1, dos : 2 }, null, ' ')
/* 输出结果:
{
"uno": 1,
"dos": 2
}
*/

var students = new Object();
students.name = "pika";
students.age = 19;
students.qq = "12345678";
var stu= new Array();
stu[0] = "name";
stu[1] = "qq";
var json = JSON.stringify(students,stu,"test")
alert(json);
/* 输出结果:
{
test"name": "pika",
test"qq": "12345678"
}
*/

 最后来总结一下,JSON.stringify()函数是用来序列化对象的,无论输入什么,输出的都是字符串类型,可以按自己的需求来定制如何序列化,输出结果是怎样的格式

https://blog.csdn.net/pika_lzy/article/details/79212476

免责声明:文章转载自《“简单form表单全代码”引发JSON.stringify()问题》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇OpenEuler gcc生成32位程序Java知识体系复习笔记下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

[php]laravel框架容器管理的一些要点

本文面向php语言的laravel框架的用户,介绍一些laravel框架里面容器管理方面的使用要点。文章很长,但是内容应该很有用,希望有需要的朋友能看到。php经验有限,不到位的地方,欢迎帮忙指正。 1. laravel容器基本认识 laravel框架是有一个容器框架,框架应用程序的实例就是一个超大的容器,这个实例在bootstrap/app.php内进行...

Qt Quick的国际化和本地化

  国际化您的应用程序 以下部分描述了国际化QML源代码的各个方面。如果您对应用程序中的所有用户界面组件都遵循这些指南,则可以针对不同语言和本地文化约定(例如日期和数字的格式化方式)本地化应用程序的各个方面。 1.对所有Literal用户界面字符串使用qsTr() 可以使用qsTr(),qsTranslate(),qsTrId(),QT_TR_NOOP...

十个PHP开发者最容易犯的错误

文章引用链接:http://www.phpxs.com/post/5974/ PHP 语言让 WEB 端程序设计变得简单,这也是它能流行起来的原因。但也是因为它的简单,PHP 也慢慢发展成一个相对复杂的语言,层出不穷的框架,各种语言特性和版本差异都时常让搞的我们头大,不得不浪费大量时间去调试。这篇文章列出了十个最容易出错的地方,值得我们去注意。 易犯错误...

java常见3种文件上传速度对比和文件上传方法详细代码

在java里面文件上传的方式很多,最简单的依然是FileInputStream、FileOutputStream了,在这里我列举3种常见的文件上传方法代码,并比较他们的上传速度(由于代码是在本地测试,所以忽略网速的影响) 还是老规矩,大神请绕一下,里屋说话。 首先呢,使用springMVC原生上传文件方法,需要一些简单的配置,不多说,上图。 1.采用sp...

Java ArrayList【笔记】

Java ArrayList【笔记】 ArrayList ArrayList基本结构 ArrayList 整体架构比较简单,就是一个数组结构 源码中的基本概念 index 表示数组的下标,从 0 开始计数 elementData 表示数组本身 DEFAULT_CAPACITY 表示数组的初始大小,默认是 10 size 表示当前数组的大小,类型 int,...

Delphi部分函数、命令、属性中文说明

Abort 函数 引起放弃的意外处理Abs 函数 绝对值函数AddExitProc 函数 将一过程添加到运行时库的结束过程表中Addr 函数 返回指定对象的地址AdjustLineBreaks 函数 将给定字符串的行分隔符调整为CR/LF序列Align 属性 使控件位于窗口某部分Alignment 属性 控件标签的文字位置AllocMem 函数 在堆栈上分...