• Ajax零基础入门 Ajax零基础入门第三天 3.2 数据交换格式


    Ajax零基础入门

    Ajax零基础入门第三天

    老师:黑马程序员

    3. Ajax加强

    3.2 数据交换格式
    3.2.1 什么是数据交换格式

    数据交换格式,就是服务器端与客户端之间进行数据传输与交换的格式。

    前端领域,经常提及的两种数据交换格式分别是 XML 和 JSON。其中 XML 用的非常少,所以,重点要学习的数据交换格式就是 JSON。

    3.2.2 XML

    【XML是什么】

    XML的英文全称是EXtensible Markup Language,即可扩展标记语言。因此,XML和HTML类似,也是一种标记语言。

    在这里插入图片描述

    【XML和HTML的区别】

    XML 和 HTML 虽然都是标记语言,但是,它们两者之间没有任何的关系。

    HTML 被设计用来描述网页上的内容,是网页内容的载体

    XML 被设计用来传输和存储数据,是数据的载体

    【XML的缺点】

    ①XML 格式臃肿,和数据无关的代码多,体积大,传输效率低

    ②在 Javascript 中解析 XML 比较麻烦

    3.2.3 JSON

    【什么是JSON】

    概念:JSON 的英文全称是 JavaScript Object Notation,即“JavaScript 对象表示法”。简单来讲,JSON 就是 Javascript 对象和数组的字符串表示法,它使用文本表示一个 JS 对象或数组的信息,因此,JSON 的本质是字符串

    作用:JSON 是一种轻量级的文本数据交换格式,在作用上类似于 XML,专门用于存储和传输数据,但是 JSON 比 XML 更小、更快、更易解析。

    现状:JSON 是在 2001 年开始被推广和使用的数据格式,到现今为止,JSON 已经成为了主流的数据交换格式。

    【JSON的两种结构】

    JSON就是用字符串来表示Javascript的对象和数组。所以,JSON中包含对象数组两种结构,通过这两种结构的相互嵌套,可以表示各种复杂的数据结构。

    【【对象结构】】

    对象结构在 JSON中表示为{} 括起来的内容。数据结构为{key: value, key: value, … } 的键值对结构。其中,key必须是使用英文的双引号包裹的字符串,value的数据类型可以是数字、字符串、布尔值、null、数组、对象6种类型。

    在这里插入图片描述

    【【数组结构】】

    数组结构在 JSON中表示为[] 括起来的内容。数据结构为[“java”,“javascript”,
    30, true … ]。数组中数据的类型可以是数字、字符串、布尔值、null、数组、对象6种类型。

    在这里插入图片描述

    【JSON语法注意事项】

    ①属性名必须使用双引号包裹

    ②字符串类型的值必须使用双引号包裹

    ③JSON 中不允许使用单引号表示字符串

    ④JSON 中不能写注释

    ⑤JSON 的最外层必须是对象或数组格式

    ⑥不能使用 undefined 或函数作为 JSON 的值

    JSON 的作用:在计算机与网络之间存储和传输数据。

    JSON 的本质:用字符串来表示 Javascript 对象数据或数组数据

    【JSON和JS对象的关系】

    JSON 是 JS 对象的字符串表示法,它使用文本表示一个JS 对象的信息,本质是一个字符串。

    //这是一个对象
    var obj = {a: 'Hello', b: 'World'}
    
    //这是一个 JSON 字符串,本质是一个字符串
    var json = '{"a": "Hello", "b": "World"}' 
    
    • 1
    • 2
    • 3
    • 4
    • 5

    【JSON和JS对象的互转】

    从 JSON 字符串转换为 JS 对象,使用 JSON.parse() 方法:

    var obj = JSON.parse('{"a": "Hello", "b": "World"}')
    //结果是 {a: 'Hello', b: 'World'}
    
    • 1
    • 2

    从 JS 对象转换为JSON 字符串,使用JSON.stringify() 方法:

    var json = JSON.stringify({a: 'Hello', b: 'World'})
    //结果是 '{"a": "Hello", "b": "World"}'
    
    • 1
    • 2

    【序列化和反序列化

    把数据对象转换为字符串的过程,叫做序列化,例如:调用 JSON.stringify() 函数的操作,叫做 JSON 序列化。

    把字符串转换为数据对象的过程,叫做反序列化,例如:调用 JSON.parse() 函数的操作,叫做 JSON 反序列化。

  • 相关阅读:
    【微服务】分布式下服务调用产生的问题之服务容错
    NM DEV Mathematics for Java 【suanshu.net免费】
    CSS-vmin&vmax单位
    docker部署项目常见的问题及解决方案
    特斯拉降价也无法阻挡国内新能源汽车厂商前进的步伐
    欧拉路径与欧拉回路
    找到所有好下标
    MySQL 生僻概念汇总
    摔杯算法(要求用最少的测试次数找出恰巧会使杯子破碎的楼层。)
    Vue.js vs React:哪一个更适合你的项目?
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/126717586