前端学习——JSON格式详解

0.前言
     JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。 易于人阅读和编写。同时也易于机器解析和生成。 它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。 这些特性使JSON成为理想的数据交换语言。
    JSON大致3种结构,JSON对象、JSON数组和JSON对象和数组嵌套。
1 JSON对象
    JSON对象简单而言便是键值对或名值对,而“值”可以是数值、字符串和布尔类型等。
    JSON对象具体格式如图1所示。
图1 JSON对象格式
 
1.1 JSON数值
    请注意数值不需要加引号,键值对之间使用","。
    【单个数值】
{“value”:12}
    【多个数值】
{"maxValue":24, "minValue":12};
 
<script>
var jsonObj = {"maxValue":24, "minValue":12};
console.log(jsonObj.maxValue);
console.log(jsonObj.minValue);
</script>
    【输出】
24
12
 
1.2 JSON字符串
    字符串需要加引号,键值对之间使用","。    
    【单个字符串】
{"name":"xukai871105"}
    【多个字符串】

{"name":"xukai871105", "blog":"http://blog.csdn.net/xukai871105"}

 
<script>
var jsonObj = {"name":"xukai871105", "blog":"http://blog.csdn.net/xukai871105"};
console.log(jsonObj.name);
console.log(jsonObj.blog);
</script>
 

    【输出】

xukai871105
http://blog.csdn.net/xukai871105
 
1.3 JSON布尔
    请注意JSON格式中的值可以使用布尔类型,且不需要加引号,如果true或false被引号包裹,那么便解析为JSON字符串,请处理稍有不同。
    
{"success":false}
 
<script>
var jsonObj = {"success":false};
console.log(jsonObj.success);
</script>
    【输出】
false
 
2 JSON数组
    JSON数组的表达方法和C语言数组的表达方法完全相同。下面的例子中存在一个JSON对象,该JSON对象只有一个键值对,键为lists而键值为JSON数组——[5,6,7,8]。这里已经存在JSON类型的嵌套,具体请看下面一个例子。
{"lists":[5,6,7,8]}
图2 JSON数组格式
<script>
var jsonObj = {"lists":[5,6,7,8]};
console.log(jsonObj.lists);
for(var i=0; i<jsonObj.lists.length; i++) {
    console.log(jsonObj.lists[i]);
}
</script>
    【输出】
[5, 6, 7, 8]
5
6
7
8 
 
3 JSON嵌套
    JSON格式可以嵌套,所谓嵌套便是JSON对象中可包括JSON数组,JSON数组中可包括JSON对象。下面的例子中rows为JSON对象,对象中嵌套JSON数组,每一个JSON数组的元素又是一个JSON对象。这种嵌套情况在实际情况中经常出现。
<script>
var jsonObj =
{ 
"total": 3, 
"rows": [ 
{ 
"title": "树莓派学习笔记——索引博文", 
"url": "http://blog.csdn.net/xukai871105/article/details/23115627" 
}, 
{ 
"title": "树莓派学习笔记——GPIO功能学习", 
"url": "http://blog.csdn.net/xukai871105/article/details/12684617" 
}, 
{ 
"title": "物联网学习笔记——索引博文", 
"url": "http://blog.csdn.net/xukai871105/article/details/23366187" 
} 
] 
};

console.log(jsonObj.total);
for(var i=0; i<jsonObj.rows.length; i++) {
    console.log(jsonObj.rows[i].title);
    console.log(jsonObj.rows[i].url);
}
</script>
    【输出】
3
树莓派学习笔记——索引博文
http://blog.csdn.net/xukai871105/article/details/23115627 
树莓派学习笔记——GPIO功能学习
http://blog.csdn.net/xukai871105/article/details/12684617 
物联网学习笔记——索引博文
http://blog.csdn.net/xukai871105/article/details/23366187
 
4.javascript中eval函数
    【为什么要加括号 】
    加上圆括号的目的是迫使eval函数在评估JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。参考——【3】 javascript eval和JSON之间的联系
<script>
var jsonStr = '{"total":3}';
var jsonObj= eval('(' + jsonStr + ')');
console.log(jsonObj.total);
</script>
  【输出】
3
 
5.常见错误
【1】多一个逗号
}或]前多一个, 这种情况不符合JSON,但是某些浏览器可以容忍,例如chrome和火狐,但是某些浏览器就无法容忍,例如IE。最好还是选择JSON校验工具测试一下JSON数据包是否合法。请注意下面一个例子中url最后的",",该逗号是多余的。
{ 
"title": "树莓派学习笔记——索引博文", 
"url": "http://blog.csdn.net/xukai871105/article/details/23115627",
}
 
6.参考资料
  • 24
    点赞
  • 124
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
前端引用.json格式动图的步骤如下: 1. 首先,需要使用require引用json文件,并在setup函数中初始化toJSON变量,以便模板使用。这是因为如果直接在标签上写图片/动画的路径,路径会被转为base64格式。但是通过require引入变量,设置静态路径,可以显示正常路径。例如:const toJSON = require('@/assets/json/half.json')。\[1\] 2. 在具体使用时,需要将animationData属性设置为toJSON变量,同时设置height和width属性来指定动画的高度和宽度。具体配置可以参考Lottie的Github文档。例如:<Vue3Lottie :animationData="toJSON" :height="13" :width="16" />。\[2\] 3. 完成以上操作后,页面加载时就能显示出动画效果了。需要注意的是,有两个小坑需要避免。首先,引入json文件时要使用require而不是import,否则json动画无法显示出来。其次,json对象里的图片地址是针对服务器项目目录的,默认是images目录,可以根据需要进行修改。同时,图片目录需要放置在项目根目录下。\[3\] 希望以上信息对您有帮助! #### 引用[.reference_title] - *1* *2* [vue3.0项目中lottie解析json动画格式](https://blog.csdn.net/mfuuty/article/details/125219376)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [vue-lottie加载json动画](https://blog.csdn.net/JJ_huahua/article/details/113179572)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值