欢迎光临散文网 会员登陆 & 注册

Flutter1.17使用JSON

2020-05-26 12:19 作者:嗨大成  | 我要投稿

JSON格式在代码编程中,是最常用的格式。那么JSON定义是什么呢?

JSON(JavaScript Object Notation, JS 对象简谱) 是一种轻量级的数据交换格式。它基于 ECMAScript (欧洲计算机协会制定的js规范)的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

简要历史

  • 1999年出现,JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。

  • 2001年 JSON是Douglas Crockford开始推广使用的数据格式

  • 2005年-2006年正式成为主流的数据格式。

  • 现在广泛应用

JSON 语法规则

JSON是一个标记符的序列。这套标记符包含六个构造字符、字符串、数字和三个字面名。

JSON是一个序列化的对象或数组。

6个构造字符

  • begin-array = ws %x5B ws ; [ 左方括号

  • begin-object = ws %x7B ws ; { 左大括号

  • end-array = ws %x5D ws ; ] 右方括号

  • end-object = ws %x7D ws ; } 右大括号

  • name-separator = ws %x3A ws ; : 冒号

  • value-separator = ws %x2C ws ; , 逗号

2. 在这6个构造字符的前或后允许存在无意义的空白符(ws):

  • ws = *(%x20 /; 空间

  • %x09 /; 水平标签

  • %x0A /; 换行或换行

  • %x0D); 回程

3.JSON的值

3.1 JSON的构成: ws 值 ws [1] 

3.2值可以是对象、数组、数字、字符串或者三个字面值(false、null、true)中的一个。值中的字面值中的英文必须使用小写。

3.3对象由花括号括起来的逗号分割的成员构成,成员是字符串键和上文所述的值由逗号分割的键值对组成,

 {

"name": "John Doe", 

"age": 18, 

"address": {

            "country" : "china", 

            "zip-code": "10000"

            }

}

3.4数组是由方括号括起来的一组值构成,如:

[3, 1, 4, 1, 5, 9, 2, 6] 

任何支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。但是对象和数组是比较特殊且常用的两种类型。

对象:对象在 JS 中是使用花括号包裹 {} 起来的内容,数据结构为 {key1:value1, key2:value2, ...} 的键值对结构。在面向对象的语言中,key 为对象的属性,value 为对应的值。键名可以使用整数和字符串来表示。值的类型可以是任意类型。

数组:数组在 JS 中是方括号 [] 包裹起来的内容,数据结构为 ["java", "javascript", "vb", ...] 的索引结构。在 JS 中,数组是一种比较特殊的数据类型,它也可以像对象那样使用键值对,但还是索引使用得多。同样,值的类型可以是任意类型。

基础示例

简单地说,JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在网络或者程序之间轻松地传递这个字符串,并在需要的时候将它还原为各编程语言所支持的数据格式,例如在 PHP 中,可以将 JSON 还原为数组或者一个基本对象。在用到AJAX时,如果需要用到数组传值,这时就需要用JSON将数组转化为字符串。 

表示对象

对象是一个无序的“‘名称/值’对”集合。一个对象以{左括号开始,}右括号结束。每个“名称”后跟一个:冒号;“‘名称/值’ 对”之间使用,逗号分隔。

{"firstName": "Brett", "lastName": "McLaughlin"}                                        

表示数组和普通的 JS 数组一样,JSON 表示数组的方式也是使用方括号 []。

"persion":[ 

{

"firstName": "Brett",            

"lastName":"McLaughlin"        

},      

{        

"firstName":"Jason",

"lastName":"Hunter"

}]}

这不难理解。在这个示例中,只有一个名为 persion的变量,值是包含两个条目的数组,每个条目是一个人的记录,其中包含名和姓。上面的示例演示如何用括号将记录组合成一个值。当然,可以使用相同的语法表示更过多的值(每个值包含多个记录)。

在处理 JSON 格式的数据时,没有需要遵守的预定义的约束。所以,在同样的数据结构中,可以改变表示数据的方式,也可以使用不同方式表示同一事物。

如前面所说,除了对象和数组,你也可以简单地使用字符串或者数字等来存储简单的数据,但这样并没有多大意义。

Flutter调用JSON例子

下载git地址:https://github.com/kenykeny1688888/jsonSample.git   

获取依赖包:flutter pub get

Flutter 通过Json可序列化进行使用

代码例子说明

定义json的格式,例子中定义下面红色部分,通过 Map<String, dynamic> toJson() => _$SerializableSimpleObjectToJson(this); OjectToJson进行转换。
import 'package:json_annotation/json_annotation.dart';
part 'serializable_simple_object.g.dart';
@JsonSerializable()
class SerializableSimpleObject {
 SerializableSimpleObject({
   this.aString,
   this.anInt,
   this.aDouble,
   this.aListOfStrings,
   this.aListOfInts,
   this.aListOfDoubles,
 });

 final String aString;
 final int anInt;
 final double aDouble;
 final List<String> aListOfStrings;
 final List<int> aListOfInts;
 final List<double> aListOfDoubles;

 factory SerializableSimpleObject.fromJson(Map<String, dynamic> json) =>
     _$SerializableSimpleObjectFromJson(json);

 Map<String, dynamic> toJson() => _$SerializableSimpleObjectToJson(this);
}

运行:flutter run

Flutter运行的JSON例子简单,这里不做动画视频直接贴图


Flutter1.17使用JSON的评论 (共 条)

分享到微博请遵守国家法律