JavaScript 基础教程JavaScript 简介JavaScript 用法JavaScript 输出JavaScript 语法JavaScript 语句JavaScript 注释JavaScript 变量JavaScript 数据类型JavaScript 对象JavaScript 函数JavaScript 作用域JavaScript 事件JavaScript 字符串JavaScript 运算符JavaScript 比较和逻辑运算符JavaScript if...else 语句JavaScript switch 语句JavaScript for 循环JavaScript while 循环JavaScript break 和 continue 语句JavaScript typeof, null, undefinedJavaScript 类型转换JavaScript 正则表达式JavaScript 错误throw try catchJavaScript 调试JavaScript 变量提升JavaScript 严格模式 (use strict)JavaScript 使用误区JavaScript 表单JavaScript 表单验证JavaScript 验证 APIJavaScript 保留关键字JavaScript JSONjavascript :void(0) 含义JavaScript 代码规范JavaScript 函数定义JavaScript 函数参数JavaScript 函数调用JavaScript 闭包JavaScript HTML DOMJavaScript DOM- 改变 HTMLJavaScript DOM - 改变 CSSJavaScript HTML DOM 事件JavaScript DOM EventListenerJavaScript DOM 元素(节点)JavaScript 对象类型JavaScript Number 对象JavaScript 字符串(String)对象JavaScript Date 对象JavaScript Array 对象JavaScript Boolean 对象JavaScript Math 对象JavaScript RegExp 对象JavaScript window 对象JavaScript window.screen 对象JavaScript window.location 对象JavaScript window.history 对象JavaScript window.navigator 对象JavaScript 弹窗JavaScript 计时事件JavaScript CookieJS中的if和switch该如何选择?JS优化多分支结构JS中的while和for循环该如何选择?JS优化循环结构JS输出杨辉三角JS定义字符串(3种方式)JS获取字符串长度JS字符串拼接/连接(3种方式)JS字符串查找(6种方法)JS截取字符串JS字符串替换replace()JS字符串大写小写转换JS字符串比较大小JS字符串和数组之间的转换JS给字符串添加HTML标签JS去除字符串前后空格JS Unicode编码和解码JS Base64编码和解码JS在接收表单数据时过滤特殊字符JS自定义编码和解码方案

JavaScript JSON

JSON 是用于存储和传输数据的格式

JSON 通常用于服务端向网页传递数据


什么是 JSON?

  1. JSON 英文全称 J ava S cript O bject N otation
  2. JSON 是一种轻量级的数据交换格式

JSON 使用 JavaScript 语法,但是 JSON 格式仅仅是一个文本

文本可以被任何编程语言读取及作为数据格式传递


范例

下面的代码定义了一个 JSON,包含了 sites 对象: 3 条网站信息(对象)的数组

{"sites":[
    {"name":"Twle", "url":"www.twle.cn"}, 
    {"name":"Google", "url":"www.google.com"},
    {"name":"Taobao", "url":"www.taobao.com"}
]}


JSON 格式化为 JavaScript 对象

JSON 格式在语法上与创建 JavaScript 对象代码是相同的

由于它们很相似,所以 JavaScript 程序可以很容易的将 JSON 数据转换为 JavaScript 对象


JSON 语法规则

  1. 数据为 键/值 对
  2. 数据由逗号分隔
  3. 大括号保存对象
  4. 方括号保存数组


JSON 数据 - 一个名称对应一个值

JSON 数据格式为 键/值 对,就像 JavaScript 对象属性

键/值对包括字段名称(在双引号中),后面一个冒号,然后是值

"name":"Twle"


JSON 对象

JSON 对象保存在大括号内

就像在 JavaScript 中, 对象可以保存多个 键/值 对

{"name":"Twle", "url":"www.twle.cn"}


JSON 数组

JSON 数组保存在中括号内

就像在 JavaScript 中, 数组可以包含对象

"sites":[
    {"name":"Twle", "url":"www.twle.cn"}, 
    {"name":"Google", "url":"www.google.com"},
    {"name":"Taobao", "url":"www.taobao.com"}
]

上面的范例中,对象 "sites" 是一个数组,包含了三个对象

每个对象为站点的信息,包括了网站名和网站地址


JSON 字符串转换为 JavaScript 对象

通常我们从服务器中读取 JSON 数据,并在网页中显示数据

简单起见,我们网页中直接设置 JSON 字符串

首先,创建 JavaScript 字符串,字符串为 JSON 格式的数据

var text = '{ "sites" : [' +
'{ "name":"Twle" , "url":"www.twle.cn" },' +
'{ "name":"Google" , "url":"www.google.com" },' +
'{ "name":"Taobao" , "url":"www.taobao.com" } ]}';

然后,使用 JavaScript 内置函数 JSON.parse() 将字符串转换为 JavaScript 对象

var obj = JSON.parse(text);

最后,在页面中使用新的 JavaScript 对象

var text = '{ "sites" : [' +
    '{ "name":"Twle" , "url":"www.twle.cn" },' +
    '{ "name":"Google" , "url":"www.google.com" },' +
    '{ "name":"Taobao" , "url":"www.taobao.com" } ]}';

obj = JSON.parse(text);
document.write(obj.sites[1].name + " " + obj.sites[1].url)


相关函数

函数描述
JSON.parse()用于将一个 JSON 字符串转换为 JavaScript 对象
JSON.stringify()用于将 JavaScript 值转换为 JSON 字符串


链接: https://www.fly63.com/course/7_500