分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 运营维护

json学习笔记(一)

发布时间:2023-09-06 01:36责任编辑:胡小海关键词:jsjson

1、JSON简介:

JSON: JavaScript Object Notation(JavaScript 对象表示法)

JSON 是存储和交换文本信息的语法。类似 XML。

JSON 比 XML 更小、更快,更易解析。

JSON 实例

{"sites": [    { "name":"华中科技大学" , "url":"www.hust.edu.cn" },     { "name":"google" , "url":"www.google.com" },     { "name":"微博" , "url":"www.weibo.com" }  ]}

1.1 什么是 JSON ?

  • JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)
  • JSON 是轻量级的文本数据交换格式
  • JSON 独立于语言:JSON 使用 Javascript语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。 目前非常多的动态(PHP,JSP,.NET)编程语言都支持JSON。
  • JSON 具有自我描述性,更易理解

1.2 JSON - 转换为 JavaScript 对象

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

  由于这种相似性,无需解析器,JavaScript 程序能够使用内建的 eval() 函数,用 JSON 数据来生成原生的 JavaScript 对象。

2、JSON 语法

  JSON 语法是 JavaScript 语法的子集。

2.1 JSON 语法规则

  JSON 语法是 JavaScript 对象表示法语法的子集。

  • 数据在名称/值对中

  • 数据由逗号分隔

  • 大括号保存对象

  • 中括号保存数组

2.2 JSON 名称/值对 

JSON 数据的书写格式是:名称/值对。

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

"name" : "华中科技大学"  等价于这条 JavaScript 语句:name = "菜鸟教程"

2.3 JSON 值  

JSON 值可以是:

  • 数字(整数或浮点数)
  • 字符串(在双引号中)
  • 逻辑值(true 或 false)
  • 数组(在中括号中)
  • 对象(在大括号中)
  • null

2.4 JSON 数字

  JSON 数字可以是整型或者浮点型:{ "age":30 }

2.5 JSON 对象 

  JSON 对象在大括号({})中书写:

  对象可以包含多个名称/值对:{ "name":"华中科技大学" , "url":"www.hust.edu.cn" }

2.6 JSON 数组

  JSON 数组在中括号中书写:

  数组可包含多个对象 

{"sites": [    { "name":"华中科技大学" , "url":"www.hust.edu.cn" },     { "name":"google" , "url":"www.google.com" },     { "name":"微博" , "url":"www.weibo.com" }  ]}

2.7 JSON 布尔值

  JSON 布尔值可以是 true 或者 false:{ "flag":true }

2.8 JSON null

  JSON 可以设置 null 值:{ "root":null }

2.9 JSON 使用 JavaScript 语法

   JSON 使用 JavaScript 语法,所以无需额外的软件就能处理 JavaScript 中的 JSON。

通过 JavaScript,您可以创建一个对象数组,并像这样进行赋值:  

var sites = [ ???{ "name":"华中科技大学" , "url":"www.hust.edu.cn" }, ????{ "name":"google" , "url":"www.google.com" }, ????{ "name":"微博" , "url":"www.weibo.com" }];

JavaScript 对象数组中的第一项(索引从 0 开始):

sites[0].name;   返回的内容是:华中科技大学

可以像这样修改数据: sites[0].name="清华大学";

2.10 JSON 文件

  • JSON 文件的文件类型是 ".json"
  • JSON 文本的 MIME 类型是 "application/json"

3 JSON 对象

语法实例:{ "name":"runoob", "alexa":10000, "site":null }

JSON 对象使用在大括号({})中书写。

对象可以包含多个 key/value(键/值)对。

key 必须是字符串,value 可以是合法的 JSON 数据类型(字符串, 数字, 对象, 数组, 布尔值或 null)。

key 和 value 中使用冒号(:)分割。

每个 key/value 对使用逗号(,)分割。

3.1访问对象值

使用点号(.)来访问对象的值:

 1 <body> 2 ?3   <p>你可以使用点号(.)来访问 JSON 对象的值:</p> 4 ?5   <p id="demo"></p> 6 ?7   <script> 8 ?9     var myObj, x;10     myObj = { "name":"runoob", "alexa":10000, "site":null };11     x = myObj.name;12     document.getElementById("demo").innerHTML = x;13 14   </script>1516 </body>

使用中括号([])来访问对象的值:

<p>你也可以使用中括号([])来访问 JOSN 对象的值:</p><p id="demo"></p><script>var myObj, x;myObj = myObj = { "name":"runoob", "alexa":10000, "site":null };x = myObj["name"];document.getElementById("demo").innerHTML = x;</script>

3.2 循环对象

  使用 for-in 来循环对象的属性: 

1 var myObj = { "name":"runoob", "alexa":10000, "site":null };2 for (x in myObj) {3 ????document.getElementById("demo").innerHTML += x + "<br>";4 }

  for-in 循环对象的属性时,使用中括号([])来访问属性的值: 

1 var myObj = { "name":"runoob", "alexa":10000, "site":null };2 for (x in myObj) {3 ????document.getElementById("demo").innerHTML += myObj[x] + "<br>";4 }

3.3 嵌套 JSON 对象

  JSON 对象中可以包含另外一个 JSON 对象:  

1 myObj = {2 ????"name":"runoob",3 ????"alexa":10000,4 ????"sites": {5 ????????"site1":"www.hust.edu.cn",6 ????????"site2":"m.hust.edu.cn",7 ????????"site3":"c.hust.edu.cn"8 ????}9 }

  使用点号(.)或者中括号([])来访问嵌套的 JSON 对象。  

x = myObj.sites.site1;// 或者x = myObj.sites["site1"];

3.4 修改值

使用点号(.)来修改 JSON 对象的值:myObj.sites.site1 = "www.google.com";使用中括号([])来修改 JSON 对象的值:myObj.sites["site1"] = "www.google.com";

3.5 删除对象属性

使用 delete 关键字来删除 JSON 对象的属性:delete myObj.sites.site1;使用中括号([])来删除 JSON 对象的属性:delete myObj.sites["site1"]

3.6 json 对象和 json 字符串的区别:

json 对象

var str2 = { "name": "asan", "sex": "man" };

json字符串

var str1 = ‘{ "name": "deyuyi", "sex": "man" }‘;

 

json学习笔记(一)

原文地址:https://www.cnblogs.com/huststl/p/8276099.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved