位置: 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教程)

  • 个体工商户超过免税额度如何收税
  • 印花税是用来干吗的
  • 医院这么开发票
  • 税务局如何认定虚开
  • 认缴后怎么才算实缴
  • 售后回租利息可以抵税吗
  • 收付实现制有应收应付吗
  • 企业所得税成本费用大于发票金额的原因
  • 应交增值税出口退税贷方余额
  • 小规模纳税人按月申报还是按季申报
  • 北京建筑施工企业排名
  • 税号里的字母是什么
  • 增值税进项税抵扣规定
  • 不得核定征收企业所得税的行业
  • etc发票犯法吗
  • 单位租房水电费是个人名字是否可以抵扣
  • 开票3个点13个点是什么意思
  • 银行承兑汇票到期怎么提示付款
  • 事业单位会计科目表及解释
  • 第三方派遣劳务不续签补偿金哪边出
  • 贷款服务开票开具要求
  • 实收资本的期初余额在借方还是贷方
  • 如何整理流水账目
  • 如何向企业支付宝收款
  • windows10出现你的电脑出现问题
  • 销售折扣收货方法有哪些
  • 支付工程款需要什么财务手续
  • 最轻薄数码相机
  • 跨年度坏账准备转回账务处理
  • php数据库连接池 实例
  • 外币交易汇兑损益包括
  • 新准则土地使用权计入固定资产还是无形资产
  • bind函数错误
  • thinkphp6框架源码完整版下载
  • 收到预付购货款
  • phpcms教程
  • 固定资产无形资产计提折旧是当月还是次月
  • 客户少给了钱怎么要
  • 床垫发票
  • 三方合同如何解除
  • 企业对外付汇怎么交税
  • 支付给临时工的费用
  • 个体工商户增值税怎么计算
  • 补贴收入属于其他收益吗
  • 管理费用算营业外支出吗
  • 固定资产的核算内容包括
  • 农业种植账务处理方法
  • 资产减值损失借贷方向
  • 单位收风险金是什么意思
  • 增值税普通发票和电子普通发票的区别
  • 服务类发票怎么做分录
  • 商场联营扣点缴纳增值税税率
  • 损益类账户借贷方向增减
  • 应收账款是否算负债
  • 营改增后建筑企业如何正确开具发票
  • 客房服务费可以开发票吗
  • 购买本公司产品未付款需要签名字吗
  • 其他商业项目
  • mysqlw3school
  • sql必会知识
  • mac怎么自动清理垃圾软件
  • bois开启usb功能
  • win10预览版和正式版区别
  • ubuntu配置vsftpd
  • win8浏览器打不开网页但能上网
  • windows7模块安装程序可以关闭吗
  • linux cvf
  • win7 64位系统怎么查看串口号?
  • 基于重大误解实施的民事法律行为
  • shell根据时间获取文件
  • bat批处理命令大全
  • easyui选项卡
  • 怎么创建pom.xml
  • unity 3渲2
  • 青岛契税优惠
  • 应交增值税减免税款借贷方向
  • 税务非正常户要提交什么资料
  • pcie3.0*4接口
  • 税务打虚打骗
  • 地税局的全称是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设