JavaWeb基础——JSON
一、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的更多相关文章
- 关于java基础、多线程、JavaWeb基础、数据库、SSM、Springboot技术汇总
作者 : Stanley 罗昊 本人自行总结,纯手打,有疑问请在评论区留言 [转载请注明出处和署名,谢谢!] 一.java基础 1.多态有哪些体现形式? 重写.重载 2. Overriding的是什么 ...
- JavaWeb基础: ServletContext
基本概念 Web容器在启动时,会为每个Web应用程序都创建一个对应的ServletContext对象,它代表当前Web应用. ServletContext(javax.servlet.http.Ser ...
- JavaWeb基础: 学习大纲
JavaWeb基础: Web应用和Web服务器 JavaWeb基础: Tomcat JavaWeb基础:HTTP协议和基于Restful的架构 JavaWeb基础: Web工程配置文件 JavaWeb ...
- 项目ITP(四) javaweb http json 交互 in action (服务端 spring 手机端 提供各种工具类)勿喷!
前言 系列文章:[传送门] 洗了个澡,准备写篇博客.然后看书了.时间 3 7 分.我慢慢规律生活,向目标靠近. 很喜欢珍惜时间像叮当猫一样 正文 慢慢地,二维码实现签到将要落幕了.下篇文章出二维码实 ...
- JavaWeb基础知识总结
JavaWeb基础知识总结. 1.web服务器与HTTP协议 Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. l Internet上供 ...
- 超详细的Java面试题总结(四 )之JavaWeb基础知识总结
系列文章请查看: 超详细的Java面试题总结(一)之Java基础知识篇 超详细的Java面试题总结(二)之Java基础知识篇 超详细的Java面试题总结(三)之Java集合篇常见问题 超详细的Java ...
- 【JavaWeb】JSON基础
JSON JavaScript Object Notation(JavaScript 对象表示法): JSON是轻量级的文本数据交换格式: JSON独立于语言,具有自我描述性,更易理解: JSON语法 ...
- [Java面试三]JavaWeb基础知识总结.
1.web服务器与HTTP协议 Web服务器 l WEB,在英语中web即表示网页的意思,它用于表示Internet主机上供外界访问的资源. l Internet上供外界访问的Web资源分为: • 静 ...
- android基础---->JSON数据的解析
上篇博客,我们谈到了XML两种常用的解析技术,详细可以参见我的博客(android基础---->XMl数据的解析).网络传输另外一种数据格式JSON就是我们今天要讲的,它是比XML体积更小的数据 ...
随机推荐
- js 中文长字符截短&关键字符隐藏 自定义过滤器
两个非常简单的过滤器:隐藏关键字符和字符截短.同样也可以迁移到ng和原生js直接使用(去掉avalon.filters声明即可).后期还有不错的过滤器,还往这里面加 keyword:avalon,js ...
- CentOS6.4 下安装 MySql5.5.13
1.卸载系统自带的MySql 1.1.查看该操作系统上是否已经安装了mysql数据库 [root@xhTest-1 ~]# rpm -qa | grep mysql 1.2.删除原mysql数据库 1 ...
- 转:asp.net 中的viewstate
概述 ViewState是一个被误解很深的动物了.我希望通过此文章来澄清人们对ViewState的一些错误认识.为了达到这个目的,我决定从头到尾详细的描述一下整个ViewState的工作机制,其中我会 ...
- Tomcat 配置学习
1 server.xml <host appBase="d:/aaa"> <Context path="/smswap" reloadable ...
- 进程分析之CPU
进程分析之CPU 进程分析之CPU 本文转载自:https://github.com/ColZer/DigAndBuried/blob/master/system/cpu.md 在<进程分析之内 ...
- September 12th 2017 Week 37th Tuesday
Failure is the fog through which we glimpse triumph. 失败是迷雾,穿过它,我们就可以瞥见光明. Sometimes the fog may be t ...
- 结合领域驱动设计的SOA分布式软件架构
引言 本文主要是参考Martion Fowler所著的<企业应用架构模式>与Eric Evans所著的<领域驱动设计>这两本泰山之作,加上本人在近年实际的工作过程中开发SOA系 ...
- python第七课——循环结构 while
while循环: 2.1.有四要素组成: ①.初始化条件(执行一次)一个起始数据/起点,一般使用变量来进行存储 ②.循环条件(可能执行多次)循环合适结束全靠它,执行结果为True,那么循环继续,反之, ...
- [USACO09JAN]Earthquake Damage
嘟嘟嘟 刚开始因为没看到只能走没有损坏的农场,磨叽了20多分钟……不管了,写题解吧. 首先如果一个点不能到达原点,那么和他相邻的点也不能到达原点,所以刚开始我们把不能走的点和他相邻的点都打上标记,然后 ...
- Hadoop学习之路(十三)MapReduce的初识
MapReduce是什么 首先让我们来重温一下 hadoop 的四大组件: HDFS:分布式存储系统 MapReduce:分布式计算系统 YARN:hadoop 的资源调度系统 Common:以上三大 ...