## 今日内容
    1. AJAX:
    2. JSON

# AJAX:
    1. 概念: ASynchronous JavaScript And XML    异步的JavaScript 和 XML
        1. 异步和同步:客户端和服务器端相互通信的基础上
            * 客户端必须等待服务器端的响应。在等待的期间客户端不能做其他操作。
            * 客户端不需要等待服务器端的响应。在服务器处理请求的过程中,客户端可以进行其他的操作。

Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。 [1] 
            通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
            传统的网页(不使用 Ajax)如果需要更新内容,必须重载整个网页页面。

提升用户的体验

2. 实现方式:
        1. 原生的JS实现方式(了解)

 //1.创建核心对象
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
} //2. 建立连接
/*
参数:
1. 请求方式:GET、POST
* get方式,请求参数在URL后边拼接。send方法为空参
* post方式,请求参数在send方法中定义
2. 请求的URL:
3. 同步或异步请求:true(异步)或 false(同步) */
xmlhttp.open("GET","ajaxServlet?username=tom",true); //3.发送请求
xmlhttp.send(); //4.接受并处理来自服务器的响应结果
//获取方式 :xmlhttp.responseText
//什么时候获取?当服务器响应成功后再获取 //当xmlhttp对象的就绪状态改变时,触发事件onreadystatechange。
xmlhttp.onreadystatechange=function()
{
//判断readyState就绪状态是否为4,判断status响应状态码是否为200
if (xmlhttp.readyState==4 && xmlhttp.status==200)
{
//获取服务器的响应结果
var responseText = xmlhttp.responseText;
alert(responseText);
}
}

2. JQeury实现方式
            1. $.ajax()
                * 语法:$.ajax({键值对});

  //使用$.ajax()发送异步请求
$.ajax({
url:"ajaxServlet1111" , // 请求路径
type:"POST" , //请求方式
//data: "username=jack&age=23",//请求参数
data:{"username":"jack","age":23},
success:function (data) {
alert(data);
},//响应成功后的回调函数
error:function () {
alert("出错啦...")
},//表示如果请求响应出现错误,会执行的回调函数 dataType:"text"//设置接受到的响应数据的格式
});

2. $.get():发送get请求
                * 语法:$.get(url, [data], [callback], [type])
                    * 参数:
                        * url:请求路径
                        * data:请求参数
                        * callback:回调函数
                        * type:响应结果的类型

3. $.post():发送post请求
                * 语法:$.post(url, [data], [callback], [type])
                    * 参数:
                        * url:请求路径
                        * data:请求参数
                        * callback:回调函数
                        * type:响应结果的类型

# JSON:
    1. 概念: JavaScript Object Notation        JavaScript对象表示法
        Person p = new Person();
        p.setName("张三");
        p.setAge(23);
        p.setGender("男");

var p = {"name":"张三","age":23,"gender":"男"};

* json现在多用于存储和交换文本信息的语法
        * 进行数据的传输
        * JSON 比 XML 更小、更快,更易解析。
    
    2. 语法:
        1. 基本规则
            * 数据在名称/值对中:json数据是由键值对构成的
                * 键用引号(单双都行)引起来,也可以不使用引号
                * 值得取值类型:
                    1. 数字(整数或浮点数)
                    2. 字符串(在双引号中)
                    3. 逻辑值(true 或 false)
                    4. 数组(在方括号中)    {"persons":[{},{}]}
                    5. 对象(在花括号中) {"address":{"province":"陕西"....}}
                    6. null
            * 数据由逗号分隔:多个键值对由逗号分隔
            * 花括号保存对象:使用{}定义json 格式
            * 方括号保存数组:[]
        2. 获取数据:
            1. json对象.键名
            2. json对象["键名"]
            3. 数组对象[索引]
            4. 遍历

  //1.定义基本格式
var person = {"name": "张三", age: 23, 'gender': true}; var ps = [{"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]);
}*/ //获取ps中的所有值
for (var i = 0; i < ps.length; i++) {
var p = ps[i];
for(var key in p){
alert(key+":"+p[key]);
}
}

3. JSON数据和Java对象的相互转换

* JSON解析器:
            * 常见的解析器:Jsonlib,Gson,fastjson,jackson
        
        1. JSON转为Java对象
            1. 导入jackson的相关jar包
            2. 创建Jackson核心对象 ObjectMapper
            3. 调用ObjectMapper的相关方法进行转换
                1. readValue(json字符串数据,Class)
        2. Java对象转换JSON
            1. 使用步骤:
                1. 导入jackson的相关jar包
                2. 创建Jackson核心对象 ObjectMapper
                3. 调用ObjectMapper的相关方法进行转换
                    1. 转换方法:
                        * writeValue(参数1,obj):
                            参数1:
                                File:将obj对象转换为JSON字符串,并保存到指定的文件中
                                Writer:将obj对象转换为JSON字符串,并将json数据填充到字符输出流中
                                OutputStream:将obj对象转换为JSON字符串,并将json数据填充到字节输出流中
                        * writeValueAsString(obj):将对象转为json字符串

2. 注解:
                        1. @JsonIgnore:排除属性。
                        2. @JsonFormat:属性值得格式化
                            * @JsonFormat(pattern = "yyyy-MM-dd")

3. 复杂java对象转换
                        1. List:数组
                        2. Map:对象格式一致

# 案例:
    * 校验用户名是否存在
        1. 服务器响应的数据,在客户端使用时,要想当做json数据格式使用。有两种解决方案:
            1. $.get(type):将最后一个参数type指定为"json"
            2. 在服务器端设置MIME类型
                response.setContentType("application/json;charset=utf-8");

Ajax&Json笔记的更多相关文章

  1. 黑马学习ajax&json 笔记

    ## 今日内容 1. AJAX: 2. JSON # AJAX: 1. 概念: ASynchronous JavaScript And XML 异步的JavaScript 和 XML 1. 异步和同步 ...

  2. struts2 + ajax + json的结合使用,实例讲解

    struts2用response怎么将json值返回到页面javascript解析,这里介绍一个struts2与json整合后包的用法. 1.准备工作 ①ajax使用Jquery:jquery-1.4 ...

  3. AJAX,JSON搜索智能提示

    效果 开发结构参考AJAX,JSON用户校验 主要有两个核心文件 1,处理输入字符,进行后台搜索的servlet Suggest.java package org.guangsoft.servlet; ...

  4. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  5. php ajax json jquery 记录

    php+jquery+ajax+json简单小例子 <html> <title>php+jquery+ajax+json简单小例子</title> <?php ...

  6. 练习 jquery+Ajax+Json 绑定数据 分类: asp.net 练习 jquery+Ajax+Json 绑定数据 分类: asp.net

    练习 jquery+Ajax+Json 绑定数据

  7. Jquery+ajax+json+servlet原理和Demo

    Jquery+ajax+json+servlet原理和Demo 大致过程: 用户时间点击,触发js,设置$.ajax,开始请求.服务器响应,获取ajax传递的值,然后处理.以JSON格式返回给ajax ...

  8. 玩转Web之Json(一)-----easy ui+ajax + json 中关于Json的解析问题

    在easy ui中使用Ajax+Json实现前后的数据交互时,当后台数据传输到客户端是需对Json数据进行解析,这里将对Json数据解析做简单总结. (一) 对于服务器返回的数据若没有做类型说明,需要 ...

  9. php+jquery+ajax+json简单小例子

    直接贴代码: <html> <title>php+jquery+ajax+json简单小例子</title> <?php header("Conte ...

随机推荐

  1. jenkins 打标签实现回滚

    背景介绍: 本项目代码存储在gitlab,再通过jenkins发布到对应的节点上. 使用tag控制版本:每一次成功的构建,jenkins会自动为gitlab的分支打上tag,版本更新可直接选择prod ...

  2. Oracle锁处理脚本

    ----处理死锁进程--查看被锁住的表select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,db ...

  3. 测试常用shell命令

    正则表达式 特殊字符 $ . ' * [ ] ^ | ( ) \ + ? awk使用心得 将抽取域在屏幕上显示和保存到文件中 awk '{print $3}' t1.txt | tee file1.t ...

  4. 大数据笔记(二十八)——执行Spark任务、开发Spark WordCount程序

    一.执行Spark任务: 客户端 1.Spark Submit工具:提交Spark的任务(jar文件) (*)spark提供的用于提交Spark任务工具 (*)example:/root/traini ...

  5. Cannot connect to the Docker daemon. Is 'docker daemon' running on this host?

    if first time to install docker, be noted the docker engine started as root copied from: http://blog ...

  6. jmeter正则表达式提取

    使用jmeter正则表达式提取器之前,首先 使用httpwatch 分析一下 我要要测试的系统正则管理的规则: 例如:我这里要关联的是一个ODS数据仓库平台的登录 1./sso/login..单点登录 ...

  7. 常见iPhone设备尺寸及分辨率(持续更新)

    开发中常用的px与pt区别 px就是表示pixel,像素,是屏幕上显示数据的最基本的点: pt就是point,是印刷行业常用单位,等于1/72英寸. px全称为pixel,是一个点,它不是自然界的长度 ...

  8. 5、Shiro之jdbcRealm认证授权

    登录认证: 注意,下面我是以连接orcal数据库为例的依赖,如果各位同仁使用的是骑她数据库,可以换成对应数据库的依赖(数据源不用换) Pom.xml增加依赖: <!--引入连接orcal的jar ...

  9. lua源码学习篇一:环境部署

    研究生即将毕业,答辩完成后,这几天有些时间.开始写一些自己的东西,记录自己的学习历程. --前言 本着学习和交流的原则,本文的内容仅供参考,而不是权威版本,如有任何问题,欢迎指出. --声明 跨专业考 ...

  10. Binary-to-text ecoding:

    binary to Text ecoding是指将二进制数据转换成可打印的符号 如果传输channel 不允许二进制数据(如email) 一般使用Base64 ASCII 标准使用128位来表示字母数 ...