一、JSON是什么?

  JSON(JavaScript Object Notation)、轻量级数据交换格式。

  JSON的后缀名:.json  JSON的MINE类型:application/json

二、JSON的格式

  以下为实际JSON举例(包含基本类型与数组类型等),理论不再赘述。

{
"name":"张三",
"id":1001,
"address":
[
{"pro":"anhui","city":"fuyang"},
{"pro":"jiangsu","city":"nanjing"}
],
"bool":true
}

  关于jsonPath,参考:https://www.cnblogs.com/weilunhui/p/3857366.html

三、如何遍历JSON

  简单JSON对象的遍历: 

            1.obj.attr

      2.obj["attr"]

      3.使用 attr in json 进行遍历:

// 遍历简单json对象
function traverseJsonSimpleObj(){
var jsonObj = {"name": "kevin", "age": 27, "sex": "男", "city": "shenzhen"};
for(var key in jsonObj){
var html = "<p>"
html += (key + ' : ' + jsonObj[key]);
html += "</p>";
$("#out").append(html);
}
}

  遍历json数组

function traverseJsonArray(){
var jsonArray = [{"name": "kevin", "age": 27, "sex": "男", "city": "shenzhen"},
{"name": "kevin2", "age": 28, "sex": "男", "city": "beijing"}];
//alert('JSON.stringify(jsonArray) = ' + JSON.stringify(jsonArray));
for(var i=0; i<jsonArray.length; i++){
var jsonObj = jsonArray[i];
for(var key in jsonObj){
var html = "<p>"
html += (key + ' : ' + jsonObj[key]);
html += "</p>";
$("#out").append(html);
}
$("#out").append("-----------------------------------------------------");
}
}

    当然,可以简写为:

 var json = [{dd:'SB',AA:'东东',re1:123},{cccc:'dd',lk:'1qw'}];
for(var i=0,l=json.length;i<l;i++){
for(var key in json[i]){
alert(key+':'+json[i][key]);
}
}

    后台直接通过springMVC等框架结合jackson,将JSON字符串放入javaBean中(属性与名称对应)(见springMVC章节)

  【更新】:实际springMVC后台@ResponseBody时返回JSON时前台的解析方法:

    后台返回数据形式:

  示例1:

@RequestMapping(value = "findAll",method = RequestMethod.GET)
@ResponseBody
public List<SimpleMenuList> findAll(HttpServletResponse response){
List<SimpleMenuList> mlList = menuListService.findAll();
/*ObjectMapper mapper = new ObjectMapper();
String jsonfromList = mapper.writeValueAsString(mlList);
System.out.println(jsonfromList);*/
//Map<String,Object> map = new HashMap<String,Object>();
// map.put("list", mlList);
// 许跨域访问
response.setHeader("Access-Control-Allow-Origin", "*");
return mlList;
}

  示例2:

  实体类:(单个属性,只为举例)

public class AssociateWord {

    private String assoWord;

    public String getAssoWord() {
return assoWord;
} public void setAssoWord(String assoWord) {
this.assoWord = assoWord;
} }

  返回List:

 for (int i =0; i<5; i++) {
AssociateWord aw = new AssociateWord();
String s = "关键字"+i;
System.out.println(s);
aw.setAssoWord(s);
list.add(aw);
}
return list;

  其他示例可参见SSM—CRUD随笔等(如返回map)

 //获得全部菜单列表
function getMenuList(){
$.ajax({
type : "get",
url : "http://localhost:8080/jeesite/f/menu_list/menuList/findAll",
success : function(result) {
console.log(result);
var jsonArray = eval(result);
alert("后台返回的菜单列表:"+jsonArray);
alert("数组长度:"+jsonArray.length);
//此处遍历点单列表
for(var i=0; i<jsonArray.length; i++){
var jsonObj = jsonArray[i];
for(var key in jsonObj){
alert(key + ' : ' + jsonObj[key]);
}
}
}
});
}

    【更新】:jQuery each遍历JSON数组:

{
"code": 100,
"msg": "操作成功",
"map": {
"pageInfo": {
"pageNum": 1,
"pageSize": 5,
"size": 5,
"startRow": 1,
"endRow": 5,
"total": 502,
"pages": 101,
"list": [
{
"empId": 1,
"empName": "Alan",
"gender": "M",
"email": "1001@qq.com",
"dId": 1,
"department": {
"deptId": 1,
"deptName": "宣传部"
}
},
{
"empId": 2,
"empName": "Bob",
"gender": "F",
"email": "1002@qq.com",
"dId": 2,
"department": {
"deptId": 2,
"deptName": "测试部"
}
},
{
"empId": 3,
"empName": "ed0b9",
"gender": "M",
"email": "ed0b9@qq.com",
"dId": 1,
"department": {
"deptId": 1,
"deptName": "宣传部"
}
},
{
"empId": 4,
"empName": "167b5",
"gender": "F",
"email": "167b5@qq.com",
"dId": 1,
"department": {
"deptId": 1,
"deptName": "宣传部"
}
},
{
"empId": 5,
"empName": "2fd6c",
"gender": "M",
"email": "2fd6c@qq.com",
"dId": 1,
"department": {
"deptId": 1,
"deptName": "宣传部"
}
}
],
"prePage": 0,
"nextPage": 2,
"isFirstPage": true,
"isLastPage": false,
"hasPreviousPage": false,
"hasNextPage": true,
"navigatePages": 5,
"navigatepageNums": [
1,
2,
3,
4,
5
],
"navigateFirstPage": 1,
"navigateLastPage": 5,
"lastPage": 5,
"firstPage": 1
}
}
}

    对上述JSON遍历如下:(result即为JSON)

//解析员工数据
function build_emps_table(result){
//员工数据
var emps = result.map.pageInfo.list;
//使用jQuery遍历数组,遍历的是取出来的json数组,可以通过开发工具查看JSON结构
$.each(emps,function(idx,item){
//使用jQuery生成各列
var empIdTd = $("<td></td>").append(item.empId);
var empNameTd = $("<td></td>").append(item.empName);
//三目运算符处理性别
var genderTd = $("<td></td>").append(item.gender=="M"?"男":"女");
var emailTd = $("<td></td>").append(item.email);
var deptName = $("<td></td>").append(item.department.deptName); });
}

JavaWeb基础——JSON的更多相关文章

  1. 关于java基础、多线程、JavaWeb基础、数据库、SSM、Springboot技术汇总

    作者 : Stanley 罗昊 本人自行总结,纯手打,有疑问请在评论区留言 [转载请注明出处和署名,谢谢!] 一.java基础 1.多态有哪些体现形式? 重写.重载 2. Overriding的是什么 ...

  2. JavaWeb基础: ServletContext

    基本概念 Web容器在启动时,会为每个Web应用程序都创建一个对应的ServletContext对象,它代表当前Web应用. ServletContext(javax.servlet.http.Ser ...

  3. JavaWeb基础: 学习大纲

    JavaWeb基础: Web应用和Web服务器 JavaWeb基础: Tomcat JavaWeb基础:HTTP协议和基于Restful的架构 JavaWeb基础: Web工程配置文件 JavaWeb ...

  4. 项目ITP(四) javaweb http json 交互 in action (服务端 spring 手机端 提供各种工具类)勿喷!

    前言 系列文章:[传送门] 洗了个澡,准备写篇博客.然后看书了.时间 3 7 分.我慢慢规律生活,向目标靠近.  很喜欢珍惜时间像叮当猫一样 正文 慢慢地,二维码实现签到将要落幕了.下篇文章出二维码实 ...

  5. JavaWeb基础知识总结

    JavaWeb基础知识总结.   1.web服务器与HTTP协议 Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. l Internet上供 ...

  6. 超详细的Java面试题总结(四 )之JavaWeb基础知识总结

    系列文章请查看: 超详细的Java面试题总结(一)之Java基础知识篇 超详细的Java面试题总结(二)之Java基础知识篇 超详细的Java面试题总结(三)之Java集合篇常见问题 超详细的Java ...

  7. 【JavaWeb】JSON基础

    JSON JavaScript Object Notation(JavaScript 对象表示法): JSON是轻量级的文本数据交换格式: JSON独立于语言,具有自我描述性,更易理解: JSON语法 ...

  8. [Java面试三]JavaWeb基础知识总结.

    1.web服务器与HTTP协议 Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. l Internet上供外界访问的Web资源分为: • 静 ...

  9. android基础---->JSON数据的解析

    上篇博客,我们谈到了XML两种常用的解析技术,详细可以参见我的博客(android基础---->XMl数据的解析).网络传输另外一种数据格式JSON就是我们今天要讲的,它是比XML体积更小的数据 ...

随机推荐

  1. mybatis 在存储Integer、bigdecimal等java数据类型时,将0存成null

    我们的项目中,有关于金额的计算,所以,一般在java环境中我们使用bigdecimal来做运算和存储金额信息.数据库sqlServer2008用的float类型 问题是,当我将金额赋值成0时,很意外的 ...

  2. apache ftp server的简单入门(properties验证)

    Apache FTPServer:(开源) Apache FTPServer是一个100%纯Java的FTP服务器. 它的设计是基于现有的开放式协议的完整和便携式FTP服务器引擎解决方案.FTPSer ...

  3. ASP.NET MVC 实现区域 项目分离 (比较好的方式)

    说明: ZRT.Web 是前台网站,目录[D:\ZRT.Web\] ZRT.Admin 是后台管理,目录[D:\ZRT.Web\Applications\Admin\],删除文件[Global.asa ...

  4. ubuntu16.04安装五笔输入法

    在 Ubuntu16.04 中为fctix小企鹅增加五笔输入法 转载:https://jingyan.baidu.com/article/454316ab67d702f7a7c03a1a.html U ...

  5. Linux命令行得到系统IP

    输入ifconfig得到 eth0 Link encap:Ethernet HWaddr :::2E:9A: inet addr:192.168.1.1 Bcast:192.168.1.255 Mas ...

  6. vo、po、dto、bo、pojo、entity、mode如何区分

    https://blog.csdn.net/qq_41604862/article/details/79675223?utm_source=blogxgwz0

  7. ArrayBlockingQueue 阻塞队列和 Semaphore 信号灯的应用

    import java.util.concurrent.ArrayBlockingQueue; import java.util.concurrent.BlockingQueue; public cl ...

  8. 关于springMVC的一些xml配置

    ①springMVC必备jar包: commons-logging-1.1.3.jar spring-aop-4.0.0.RELEASE.jar spring-beans-4.0.0.RELEASE. ...

  9. 获取索引--------用range()和len()

    a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ'] for i in range(len(a)): print(i+1,a[i])

  10. UI(二)之正式过程

    2018-12-04 09:48:25 1.SetWindowsHookEx ·钩子实际上是一个处理消息的程序段,通过系统调用,把它挂入系统.每当特定的消息发出,在没有到达目的窗口前,钩子程序就先捕获 ...