位置: IT常识 - 正文

JavaScript核心技术之JSON详解(javascript核心技术)

编辑:rootadmin
JavaScript核心技术之JSON详解 JSON是什么?

推荐整理分享JavaScript核心技术之JSON详解(javascript核心技术),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript的核心组成部分有哪些,javascript的核心组成部分有哪些,javascript的核心组成部分有哪些,javascript核心技术开发解密pdf,javascript核心技术开发解密,javascript的核心,javascript核心技术开发解密下载,javascript核心技术开发解密,内容如对您有帮助,希望把文章链接给更多的朋友!

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

JSON源自于JavaScript,是一种轻量级(Light-Meight)、基于文本的(Text-Based)、可读的(Human-Readable)格式。

在现在的开发中,能够进行数据交换格式的,包括两个JSON   XML。

JSON是存储和交换文本信息的语法,类似 XML,JSON比 XML更小、更快,更易解析。

 那么,简而言之,对JSON的说明总结如下:

JSON是独立于任何编程语言的数据格式是一种用于存储和传输数据的轻量级格式语法是自描述的,便于人类阅读和理解JSON语法基本语法:数组(Array)用方括号 "[]" 表示对象(0bject)用大括号 "{}" 表示名称 / 值 对(name/value)组合成数组和对象名称( name )置于双引号中,值(value)有字符串、数值、布尔值、null、对象和数组并列的数据之间用逗号 "," 分隔名称/值对包括字段名称(在双引号中),后面写一个冒号,然后是值

需要注意的是:

JSON不支持注释。向 JSON添加注释无效

JSON文件的文件类型是 .json

JSON文本的 MIME 类型是 application/json

获取JSON数据

 json是以对象的形式存在的,直接获取JSON数据可通过如下方法:

1. json对象.键名

2. json对象["键名"]

3. 数组对象[索引]

4. 遍历 

JavaScript核心技术之JSON详解(javascript核心技术)

代码示例:

//定义基本格式 var person = { name: "张三", age: 23, gender: true }; var persons = [ { name: "张三", age: 23, gender: true }, { name: "李四", age: 24, gender: true }, { name: "王五", age: 25, gender: false }, ]; //获取person对象中所有的键和值 //for in 循环 /* for(var key in person){ //这样的方式获取不行。因为相当于 person."name" //alert(key + ":" + person.key); alert(key+":"+person[key]); }*/ //获取persons中的所有值 for (var i = 0; i < persons.length; i++) { var p = persons[i]; for (var key in p) { console.log(key + ":" + p[key]); } }

 输出结果为:

 JSON 解析与序列化(在JavaScript中)

先在控制台中打印一下JSON对象,看看有什么,如图:

 显而易见,在JavaScript中JSON对象仅有两个方法:parse和stringify。后面会详细介绍一下这两个方法

序列化的概念:序列化是将对象转化为字节序列的过程。对象序列化后可以在网络上传输,或者保存到硬盘上。

将对象序列化成json字符串: JSON.stringify(json对象);

反序列化:将json字符串反序列化为对象:   JSON.parse(str)

JSON.parse

API介绍:用来解析 JSON字符串,构造由字符串描述的 JavaScript 值或对象,传入的字符串不符合 JSON规范会报错

语法:

JSON.parse(str, reviver);str:要解析的 JSON字符串reviver:可选的函数 function(key,value),该函数的第一个参数和第二个参数分别代表键值对的键和值,并可以对值进行转换(函数返回值当做处理后的value)

代码示例:

// JSON.parse() 解析JSON字符串, 将JSON转换为对象 let json = '{"name": ["js", "webpack"], "age": 22, "gridFriend": "ljj"}'; console.log(JSON.parse(json)); // {name: Array(2), age: 22, gridFriend: 'ljj'} // 第二个参数是一个函数,key和value代表每个key/value对 let result = JSON.parse(json, (key, value) => { if (key == "age") { return `年龄:${value}`; } return value; }); console.log(result); //{name: Array(2), age: '年龄:22', gridFriend: 'ljj'} JSON.stringify

API介绍:将一个 JavaScript 对象或值转换为 JSON字符串

如果指定了一个 replacer 函数,则可以选择性地替换值,或者指定的 replacer 是数组,则可选择性地仅包含数组指定的属性

语法:

JSON.stringify(value, replacer, space)

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

replacer:

如果该参数是一个函数,则在序列化过程中,被序列化的值的每个属性都会经过该函数的转换和处理如果该参数是一个数组,则只有包含在这个数组中的属性名才会被序列化到最终的 JSON 字符串中如果该参数为 null 或者未提供,则对象所有的属性都会被序列化

space:指定缩进用的空白字符串,用于美化输出

如果参数是个数字,它代表有多少的空格;上限为10。该值若小于1,则意味着没有空格如果该参数为字符串(当字符串长度超过10个字母,取其前10个字母),该字符串将被作为空格如果该参数没有提供(或者为 null),将没有空格

代码示例:

let obj = { name: "jsx", age: 22, lesson: ["html", "css", "js"], }; let json = JSON.stringify(obj); console.log(json); // {"name":"jsx","age":22,"lesson":["html","css","js"]} // 第二个参数replacer 为函数时,被序列化的值得属性都会经过该函数转换处理 function replacer(key, value) { if (typeof value === "string") { return undefined; } return value; } let result = JSON.stringify(obj, replacer); console.log(result); // {"age":22,"lesson":[null,null,null]} // 当replacer参数为数组,数组的值代表将被序列化成 JSON 字符串的属性名 let result1 = JSON.stringify(obj, ["name", "lesson"]); // 只保留 “name” 和 “lesson” 属性值 console.log(result1); // {"name":"jsx","lesson":["html","css","js"]} // 第三个参数spcae,用来控制结果字符串里面的间距 let result2 = JSON.stringify(obj, null, 4); console.log(result2); /*{ "name": "jsx", "age": 22, "lesson": [ "html", "css", "js" ] }*/

 注意:如果replacer是一个函数,则该函数会进行深处理,即如果键值对的值也是一个数组,则也会执行该函数

JSON.stringify()原理转换值如果有 toJSON() 方法,该方法定义什么值将被序列化非数组对象的属性不能保证以特定的顺序出现在序列化后的字符串中布尔值、数字、字符串的包装对象在序列化过程中会自动转换成对应的原始值,undefined、任意的函数以及 symbol 值,在序列化过程中会被忽略(出现在非数组对象的属性值中时)或者被转换成 null(出现在数组中时)。函数、undefined 被单独转换时,会返回 undefined,如JSON.stringify(function(){}) or JSON.stringify(undefined)对包含循环引用的对象(对象之间相互引用,形成无限循环)执行此方法,会抛出错误所有以 symbol 为属性键的属性都会被完全忽略掉,即便 replacer 参数中强制指定包含了它们Date 日期调用了 toJSON() 将其转换为了 string 字符串(同Date.toISOString()),因此会被当做字符串处理NaN 和 Infinity 格式的数值及 null 都会被当做 null其他类型的对象,包括 Map/Set/WeakMap/WeakSet,仅会序列化可枚举的属性
本文链接地址:https://www.jiuchutong.com/zhishi/298805.html 转载请保留说明!

上一篇:Win11装了VMware后找不到wifi网络的解决方法(虚拟机安装win11提示无法运行)

下一篇:Qt+OpenCV(一)Qt基础操作和使用opencv初识(qt+opencv教程)

  • 支付宝划一划是什么(支付宝划一划有什么用)

    支付宝划一划是什么(支付宝划一划有什么用)

  • 苹果13是20w还是25w(苹果13还是20w吗)

    苹果13是20w还是25w(苹果13还是20w吗)

  • 抖音怎么置顶关注的人(抖音怎么置顶关注好友)

    抖音怎么置顶关注的人(抖音怎么置顶关注好友)

  • 快手哪个版本可以看别人收藏的视频(快手哪个版本可以发视频赚钱)

    快手哪个版本可以看别人收藏的视频(快手哪个版本可以发视频赚钱)

  • 一淘拼单是什么(一淘可以返利拼多多吗)

    一淘拼单是什么(一淘可以返利拼多多吗)

  • 截屏发送不了怎么回事(截屏发送不出去)

    截屏发送不了怎么回事(截屏发送不出去)

  • oppo电量显示变成黑色(oppo电量显示变成白色)

    oppo电量显示变成黑色(oppo电量显示变成白色)

  • win10高级启动是什么(window10的高级启动)

    win10高级启动是什么(window10的高级启动)

  • 计算器数字键没反应了咋回事(计算器数字键没反应)

    计算器数字键没反应了咋回事(计算器数字键没反应)

  • 华为相册删除照片里清空了能恢复吗(华为相册删除照片删不掉)

    华为相册删除照片里清空了能恢复吗(华为相册删除照片删不掉)

  • 手机wps有艺术字吗(手机wps有艺术字功能吗)

    手机wps有艺术字吗(手机wps有艺术字功能吗)

  • 同一wifi检测不到dlna(在同一wifi下为什么搜索不到设备)

    同一wifi检测不到dlna(在同一wifi下为什么搜索不到设备)

  • qq显示开车中是什么意思(qq开车会封号吗)

    qq显示开车中是什么意思(qq开车会封号吗)

  • 华为笔记本蓝屏重启不了(华为笔记本蓝屏怎么回事)

    华为笔记本蓝屏重启不了(华为笔记本蓝屏怎么回事)

  • 电容麦必须配声卡吗(电容麦克风需要配电源吗)

    电容麦必须配声卡吗(电容麦克风需要配电源吗)

  • 家用wifi去哪办(家里装wifi去哪里办理)

    家用wifi去哪办(家里装wifi去哪里办理)

  • myaal10是什么手机(myaal10是华为什么型号手机)

    myaal10是什么手机(myaal10是华为什么型号手机)

  • 苹果11通话记录保存多久(苹果11通话记录怎么查询更早)

    苹果11通话记录保存多久(苹果11通话记录怎么查询更早)

  • 卡贴机开不了热点(卡贴机用不了了)

    卡贴机开不了热点(卡贴机用不了了)

  • 手机怎样添加网络(手机怎样添加网络密码)

    手机怎样添加网络(手机怎样添加网络密码)

  • 手提电脑关闭了无线功能怎样开启(手提电脑关闭了怎么开机)

    手提电脑关闭了无线功能怎样开启(手提电脑关闭了怎么开机)

  • 电脑怎么连接手机个人热点(电脑怎么连接手机投屏)

    电脑怎么连接手机个人热点(电脑怎么连接手机投屏)

  • 淘宝怎么变回健康宝宝(淘宝怎么变回健康模式)

    淘宝怎么变回健康宝宝(淘宝怎么变回健康模式)

  • mate30rs什么时候上市(mate30rs手机多少钱)

    mate30rs什么时候上市(mate30rs手机多少钱)

  • 探探不开会员匹配不到(探探不开会员不能玩吗)

    探探不开会员匹配不到(探探不开会员不能玩吗)

  • 爱奇艺多次启动失败怎么办(爱奇艺多次启动怎么关闭)

    爱奇艺多次启动失败怎么办(爱奇艺多次启动怎么关闭)

  • vivo X27支持双卡吗(vivox27支持双卡双4g吗)

    vivo X27支持双卡吗(vivox27支持双卡双4g吗)

  • tim在线是什么(tim各种在线状态解读)

    tim在线是什么(tim各种在线状态解读)

  • 不能跨年
  • 国税地税电子钥匙价格
  • 全年交多少税可以退
  • 民间非营利性组织收到个税手续费返还
  • 企业购买房产如何列入投资计划的
  • 一个公司两个纳税人识别号
  • 买商品送购物券合法吗
  • 季度不超9万
  • 一般纳税人可以开1%的发票吗
  • 矿产资源税是多少
  • 项目资本金是什么意思大白话
  • 汇算清缴需要调增的费用
  • 中标费用由哪方出
  • 租个人房屋办公怎么租
  • 利润表适用执行小企业
  • 出口退税最新规定2021
  • 临时工工资单怎么做
  • 购进货物不能抵扣进项税额
  • coms恢复默认设置
  • 电脑显示器模糊不清晰是什么原因
  • win7缓存设置方法
  • 为什么浏览器自动打开
  • 广告公司广告费会计分录
  • .linux文件
  • 借款人约定分期还款中途可以起诉吗
  • 铁杆茉莉的养殖方法
  • 现金流量套期的例子
  • php数组函数输出《咏雪》里有多少"片"字
  • 建筑业异地施工可以先开发票么
  • 结转本年利润的分录怎么写
  • 玉兰种院子什么方位
  • 无形资产使用寿命不确定需要摊销吗
  • 每个建筑项目都有监理吗
  • node.js如何安装
  • 预缴土地增值税的税率
  • go开发web项目
  • vue实现登陆
  • 小规模纳税人申报表模板
  • 生活服务业纳税义务发生时间
  • 增值税专票的开票要求
  • 什么叫误餐费
  • 进口货物的账务处理办法
  • 固定资产货币化,货币资产保险化,保险资产信托化
  • u8已经记账的凭证怎么修改
  • 资产负债表第二年怎么填
  • 15个postgresql数据库实用命令分享
  • 在建工程领用自产应税消费品
  • 退物业费如何记帐
  • 劳动合同没有齐缝章
  • 购买的商品用于什么
  • 购买理财产品现金流量表
  • 把其他应付款转成实收资本的话需要去工商改注册资本么
  • 传媒公司的骗局把戏
  • 应交税费其他收入会计分录
  • 奖励员工购物卡怎么写
  • 商品买一送一应该怎么写
  • 什么情况需要预缴
  • 其他权益工具确认递延所得税负债
  • 公司发放工资的形式
  • CREATE FUNCTION sqlserver用户定义函数
  • win7 32位旗舰版电脑城下载
  • linux支持多种平台
  • fedora系统怎么样
  • 怎样u盘安装系统软件
  • 出现闪退该怎么办
  • xp系统ie浏览器怎么升级
  • xp系统如何清除所有盘的东西
  • linux恢复rm删除目录
  • win8光盘安装
  • 2016年Win10 RS1预览版11095已送交合作伙伴
  • opengl多窗口绘图
  • easyui grid
  • node.js入门教程
  • jsp中onload事件
  • [置顶]津鱼.我爱你
  • python队列只能一个个读取吗
  • javascript模块化规范
  • 湖南省电子税务局登录
  • 东莞市国税局南城莫
  • 国家土地征收管理办法
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设