2018,狗年。如果在你出生日期的年份上加12等于2018的话,私聊我,今年是你的本命年,你得发红包!!!

子(鼠)、丑(牛)、寅(虎)、卯(兔)、辰(龙)、巳(蛇)、午(马)、未(羊)、申(猴)、酉(鸡)、戌(狗)、亥(猪)

JSON:JavaScript 对象表示法(JavaScript Object Notation),是轻量级的文本数据交换格式。类似 XML,但比XML 更小、更快,更易解析。

  从上面这句话可以看出:<1> JSON 是纯文本

             <2> JSON 具有层级结构(类似XML,键值对)

             <3> JSON 可通过 JavaScript 进行解析

个人理解为:JSON 是 在js中处理对象和交换数据的,采用键值对方式存贮数据的文本轻量级格式。

JSON 语法:<1> 数据在键/值对中

      <2> 数据由逗号分隔                                                   

      <3> 花括号保存对象    --->   { "name":"zhangs" , "year":"18" }                                  

      <4> 方括号保存数组    --->   { "employees" :[{ " name":"zhangs" , "year":"18" } ,{ " name":"zhangs" , "year":"18" }] }   (多个对象)

  获取数据:employees[0].name;

接下来,就讲解几种常用的 json 数据处理 (java 和 jsp)

一、jsp -->java

 1.json 操作多个实体对象(列如保存提交多个对象,采用序列化表单,json转换)

    jsp
      <input type="hidden" id="inputForm" name="inputForm"/> 
    js
      var inputForm = $("#inputForm").serializeObject();
      $("#inputForm").val(JSON.stringify(inputForm));
    java
    String inputForm = request.getParameter("inputForm");
    Employee employee = (Employee) JsonMapper.fromJsonString(inputForm, Employee.class); //(转成实体对象,不能获取冗余的其他对象)
    JSONObject json = new JSONObject(inputForm); //(转成Json对象)
    String name = json.getString("project.name"); //(获取其他对象值)
    String linkphone = json.getString("project.linkphone");

二、java -->jsp

1.json 集合转json
  java
    List<Employee> employeeList = proinfoService.findMapList(employee);
    model.addAttribute("employeeList", JsonMapper.getInstance().toJson(employeeList));

  js
    对于服务器返回的JSON字符串,如果请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,要将该字符串放于eval()中执行一次。
  $.each(eval(employeeList),function(n,value) {
  String name = value.name;
  });
    由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。
2.json 操作对象集合(用于动态加载集合数据)
  java 返回List<Employee>
  Page<Employee> page = new Page<Employee>(Integer.valueOf(start), Integer.valueOf(count));
  String organId = request.getParameter("organId");
  Employee employee = new Employee();
  employee.setIntermediaryid(organId);
  page = employeeService.findPage(page, employee);
  return page.getList();   js
  $.ajax({
  url: '/outer/getEmployeeList',
   type: 'post',
   data: 'start='+start+'&count='+pageSize+'&organId='+organId,
  dataType: 'json',
  success: function(data){
  var str = "";
  for(i = 0; i < data.length; i++){
   if(0 == i%2){
              //(turnToEmployee(\''+ data[i].id + '\') -- \' 转义 单眼号 '  )
   str += '<tr style="background-color:#F4F7FB" onclick="turnToEmployee(\''+ data[i].id + '\')">' + '<td>' + data[i].name+ '</td>';
   }else{
   str += '<tr onclick="turnToEmployee(\''+ data[i].id + '\')">' + '<td>' + data[i].name+ '</td>';
  }
  str += '<td>' + data[i].idcard+ '</td>' ;
  str += '<td>' + data[i].linkphone+'</td>'
  str += '<td>' + data[i].workyear+'</td>'
   }
  $(".listTable tbody").empty();
  $(".listTable tbody").append(str);
  }
  });
3.很特殊的一种 json 操作String集合
  java 返回List<String>
  List 中的元素是按照 add 顺序加载的,并且里面有重复的元素。这就是有序可重复的意思。
  Set 中的元素并没有按照 add 顺序加载的,并且里面没有重复的元素。这就是无序不可重复的意思。   List<String> temp = Lists.newArrayList();
   temp.add(p.getName());
  HashSet<String> h = new HashSet<String>(temp); //(用hashSet 去重顺序不变,集合类型得相匹配)
   temp.clear();
   temp.addAll(h);
   return JsonMapper.toJsonString(temp);   jsp
   $.ajax({
  url: "",
   type: 'post',
   data: '',
   dataType: 'json',
   async: false,
   success: function(data){
   $("#"+data[d]).css("background", "#6699FF");
   }
   });

最后再提两个知识点:JSON.parse()    JSON.stringify()

parse 用于从一个字符串中解析出对象 eg:

  var str = '{"name":"zhangs","age":"18"}';

  JSON.parse(str); -- >name : "zhangs"

            -- >age : "18"

stringify 用于把对象解析成字符串 eg:

  var obj = {name: "zhangs" , age: "18"};

  JSON.stringify(obj); -- > '{"name":"zhangs","age":"18"}';

人依旧,物依然,又是一年;想也好,忘也罢,本是平凡;今儿好,明更好,衷心祝愿;情也真,意也切,常驻心间。提前预祝2018年新年快乐!!!

    

JSON 数据操作的更多相关文章

  1. python 发送json数据操作实例分析 - python

    文章来源:嗨学网 敏而好学论坛www.piaodoo.com 欢迎大家相互学习 本文实例讲述了python 发送json数据操作.分享给大家供大家参考,具体如下: # !/usr/bin/env py ...

  2. ajax 返回json数据操作

    例子: $.ajax({ url: "<?=Url::toRoute('add-all-staff')?>", type: 'get', dataType: 'json ...

  3. python json 数据操作

    python 有专门针对 json 操作的函数 #!/usr/bin/python3 import json mytest_js = { "a" : 1, "b" ...

  4. SparkSQL JSON数据操作(1.3->1.4)

    1.用户自定义schema data json串格式如下: { "partner_code": "demo", "app_name": &q ...

  5. js常用JSON数据操作

    JSON字符串: var  str = '{"name": "jack", "age": 13}'; JSON对象: var obj = { ...

  6. json数据操作

    <!DOCTYPE HTML> <html> <head> <meta charset="utf-8"> <title> ...

  7. Java读取json文件并对json数据进行读取、添加、删除与修改操作

    转载:http://blog.csdn.net/qing_yun/article/details/46865863#t0   1.介绍 开发过程中经常会遇到json数据的处理,而单独对json数据进行 ...

  8. js之操作JSON数据

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式.同时,JSON是 JavaScript 原生格式,这意 ...

  9. js中如何操作json数据

    一.要想熟练的操作json数据,就先要了解json数据的结构,json有两种结构:对象和数组. 1.对象 一个对象以“{”开始,“}”结束.每个“名称”后跟一个“:”:“‘名称/值’ 对”之间使用“, ...

随机推荐

  1. make工程管理器

    1.概述 大型程序中,人们希望工具自动识别修改的文件,而且不需要输入冗长的命令,就可以进行编译链接等操作,于是make工程管理器应运而生. make可以自动识别文件时间戳,只处理修改的文件: make ...

  2. dedecms在php7下的使用方法,织梦dedecsm后台一片空白的解决方法

    前几天,一个老客户,最近升级了服务器,php到php7,把织梦dedecms转移到新服务器后,不能登录后台,让帮忙看一下. 我看了下他们的网站,使用的是织梦V57_UTF8_SP1前台页面是可以访问的 ...

  3. iOS自定义文字高度添加行间距

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Menlo; color: #000000 } span.s1 { } span.s2 { c ...

  4. js验证input输入框(字母,数字,符号,中文)

    [javascript]代码库 <h1>js验证输入框内容</h1> <br /> <br /> 只能输入英文 <input type=" ...

  5. Visual simultaneous localization and mapping: a survey 论文解析(全)

    当激光或声纳等距离传感器被用来构建小的静态环境的二维地图时,SLAM的问题被认为是解决的.然而,对于动态,复杂和大规模的环境,使用视觉作为唯一的外部传感器,SLAM是一个活跃的研究领域. 第一部分是简 ...

  6. SpringMVC对包的扫描范围扩大后,导致的事务配置不生效问题

    问题场景 项目使用的框架:Spring 4.1.4 + Hibernate 4.3.8 + MySQL. web.xml中对Spring的配置: <!-- 把 Spring 容器集成到 Web ...

  7. css清除浮动主要方法

    1.浮动元素尾部添加空div标签,设置css为clear:both: 缺点:如果页面浮动布局多,则需要添加较多div: 2.父级元素定义伪类:after和zoom:1: .father:after{d ...

  8. Spring之DAO一

    前面博客把bean.aop简单了解了一下,今天主要是了解Spring中DAO层,如果使用传统的JDBC时需要创建连接.打开.执行sql.关闭连接这一系列的步骤,Spring框架对JDBC进行了封装,我 ...

  9. 自动生成getter,setter方法的插件lombok

    1.在InteiliJ IDEA上安装lombok插件,并重启 . 2.在pom.xml文件中添加依赖 <dependency>    <groupId>org.project ...

  10. 手动编译protobuf3的C++源码

    Windows下编译 官方文档 第三方文档 准备工具 Visual Studio 2013 CMake https://cmake.org/ Git https://git-scm.com/ 需要注意 ...