Ajax

Ajax介绍

“Asynchronous Javascript And XML”(异步JavaScript和XML),并不是新的技术,只是把原有的技术,整合到一起而已。
1.使用CSS和XHTML来表示。
2. 使用DOM模型来交互和动态显示。
3.使用XMLHttpRequest来和服务器进行异步通信。
4.使用javascript来绑定和调用。

–>使用 JavaScript 的 XMLHttpRequest 对象来直接与服务器进行通信。
–>通过这个对象,您的 JavaScript 可在不重载页面的情况与 Web 服务器交换数据。
–>AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。

AJAX 可使因特网应用程序更小、更快,更友好。
AJAX 是一种独立于 Web 服务器软件的浏览器技术。

Json介绍

采用完全独立于编程语言的文本格式来存储和表示数据

简洁和清晰,结构层次使得JSON称为理想的交换语言

易于阅读和编写,同时也易于及其解析和生成,并有效地提升网络传输效率

简述

数据交换的格式,与语言无关,最早诞生在js上
json在js中是一种对象Object类型

格式

数组形式
var jsonString = “[el1,el2,el3]”
–> 元素,类型不限制
对象形式
var jsonString=”{
属性名:属性值,
属性名:属性值,
属性名:属性值,
属性名:属性值,
…..
}”

例子

//数组形式1
    var json1String = "['哈哈',1,true,'你好']";
    // alert(typeof json1String);
    var json1 = eval("("+json1String+")");
    // alert(typeof json1);
    // alert(json1[2])
//数组形式2
    var json2String = ['哈哈',1,true,'你好'];
    alert(typeof json2String)
//对象形式
    var json3 = {
        "name":"小明",
        "age":"12",
        "email":"123@123.com",
        "hobby":["呵呵","哈哈","嘿嘿"]
    };
//解析
    alert(json3.name);
    alert(json3.hobby[2]);
//多个对象形式
    var json4=[{
        "name":"小明",
        "age":"12",
        "email":"123@123.com",
        "hobby":["呵呵","哈哈","嘿嘿"]
        },
        {
            "name":"小红",
        "age":"16",
        "email":"123@123.com",
        "hobby":["呵呵","哈哈","嘿嘿"]},
        {
            "name":"小楼",
        "age":"19",
        "email":"123@123.com",
        "hobby":["呵呵","哈哈","嘿嘿"]
        }
        ];
    alert(json4[2].name);

JSON工具

Jsonlib
JsonObject.fromObject(javaBean|map) – json对象形式
JsonArray.fromArray(list|Array) – 数组和list格式

例子

@Test
public void test(){
    String[] arrs = {"大洼","二娃","三娃"};
    JSONArray jsonArray = JSONArray.fromObject(arrs);
    System.out.println(jsonArray);
}

@Test

public void test2(){
    ArrayList<String> list =new ArrayList<>();
    list.add("111");
    list.add("222");
    list.add("333");
    JSONArray jsonArray = JSONArray.fromObject(list);
    System.out.println(jsonArray);
}

@Test
public void test3(){
    Map<String,String> map = new HashMap<>();
    map.put("111","111");
    map.put("222","222");
    map.put("333","333");

    JSONObject jsonObject = JSONObject.fromObject(map);
    System.out.println(jsonObject);
}

@Test
public void test4(){
    User user = new User(1,"小红");
    JSONObject jsonObject = JSONObject.fromObject(user);
    System.out.println(jsonObject);
}

@Test
public void test5(){
    ArrayList<User> arrayList = new ArrayList();
    User user = new User(1,"小红");
    User user2 = new User(2,"小青");
    arrayList.add(user);
    arrayList.add(user2);
    JSONArray jsonArray = JSONArray.fromObject(arrayList);
    System.out.println(jsonArray);
}

数据请求 Get

1.创建对象
获取XmlHttpRequest对象
function getXMLHttpRequest() {
    var xmlHttpReq=null;
    if (window.XMLHttpRequest) {//Mozilla 浏览器
        xmlHttpReq = new XMLHttpRequest();
    }else {
        if (window.ActiveXObject) {//IE 浏览器
            try {
                xmlHttpReq = new ActiveXObject("Microsoft.XMLHTTP");
            }
            catch (e) {
                try {//IE 浏览器
                    xmlHttpReq = new ActiveXObject("Msxml2.XMLHTTP");
                }
                catch (e) {
                }
            }
        }
    }
    return xmlHttpReq;
}


2. 发送请求
仅发送请求
--> 写在jsp

执行get请求
function get() {

//1. 创建xmlhttprequest 对象
var request = ajaxFunction();

//2. 发送请求。
// http://localhost:8080/day16/demo01.jsp
//http://localhost:8080/day16/DemoServlet01

/*
参数一: 请求类型 GET or POST
参数二: 请求的路径
参数三: 是否异步, true or false
*/
request.open("GET" ,"/day16/DemoServlet01" ,true );
request.send();
}

发送请求的同时,还想获取数据
​
//执行get请求
function get() {

//1. 创建xmlhttprequest 对象
var request = ajaxFunction();

//2. 发送请求
request.open("GET" ,"/day16/DemoServlet01?name=aa&age=18" ,true );

//3. 获取响应数据 注册监听的意思。 一会准备的状态发生了改变,那么就执行 = 号右边的方法
request.onreadystatechange = function(){

//前半段表示 已经能够正常处理。 再判断状态码是否是200
if(request.readyState == 4 && request.status == 200){
//弹出响应的信息
alert(request.responseText);
}
}
request.send();
}

数据请求 Post


​       <script type="text/javascript">
1. 创建对象
function ajaxFunction(){
  var xmlHttp;
  try{ // Firefox, Opera 8.0+, Safari
      xmlHttp=new XMLHttpRequest();
  }
  catch (e){
  try{// Internet Explorer
        xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
    }
  catch (e){
    try{
        xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    catch (e){}
    }
  }
​
return xmlHttp;
}
​
function post() {
//1. 创建对象
var request = ajaxFunction();

2. 发送请求
request.open( "POST", "/day16/DemoServlet01", true );
​
//如果不带数据,写这行就可以了
//request.send();

//如果想带数据,就写下面的两行

//如果使用的是post方式带数据,那么 这里要添加头, 说明提交的数据类型是一个经过url编码的form表单数据
request.setRequestHeader("Content-type","application/x-www-form-urlencoded");

//带数据过去 , 在send方法里面写表单数据。
request.send("name=aobama&age=19");
}
</script>

发送请求 并 需要获取数据
function post() {
//1. 创建对象
var request = ajaxFunction();

//2. 发送请求
request.open( "POST", "/day16/DemoServlet01", true );

//想获取服务器传送过来的数据, 加一个状态的监听。
request.onreadystatechange=function(){

if(request.readyState==4 && request.status == 200){
alert("post:"+request.responseText);
}
}

//如果使用的是post方式带数据,那么 这里要添加头, 说明提交的数据类型是一个经过url编码的form表单数据
request.setRequestHeader("Content-type","application/x-www-form-urlencoded");

//带数据过去 , 在send方法里面写表单数据。
request.send("name=aobama&age=19");
}

Jquery方式发送数据

<script type="text/javascript" src="../jq/jquery.js"></script>
<script type="text/javascript">
    $(function () {
        $("#btn").click(function () {
            var url = "/develop_iservlet_ajax/hello";
            var params = "name=zhangsan";
            $.get(url,params,function (data) {
                $("#div").html(data);
            });
        });
    })
</script>

校验用户名是否可用

1. 搭建环境

1.页面准备
<body>  
<table border="1" width="500">      
<tr>            
<td>用户名:</td>           
<td><input type="text" name="name" id="name"  onblur="checkUserName()"><span id="span01"></span></td>       
</tr>       
<tr>            
<td>密码</td>         
<td><input type="text" name=""></td>        
</tr>       
<tr>            
<td>邮箱</td>         
<td><input type="text" name=""></td>        
</tr>       
<tr>            
<td>简介</td>         
<td><input type="text" name=""></td>        
</tr>       
<tr>            
<td colspan="2"><input type="submit" value="注册"></td>       
</tr>   
</table>   
</body>

2.数据库准备

  1. Servlet代码
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {

request.setCharacterEncoding("UTF-8");

//1. 检测是否存在
String name = request.getParameter("name");
System.out.println("name="+name);

UserDao dao = new UserDaomImpl();
boolean isExist = dao.checkUserName(name);

//2. 通知页面,到底有还是没有。
if(isExist){
response.getWriter().println(1); //存在用户名
}else{
response.getWriter().println(2); //不存在该用户名
}

} catch (SQLException e) {
e.printStackTrace();
}
}

3. Dao代码
public class UserDaomImpl implements UserDao{@Override
public boolean checkUserName(String username) throws SQLException {
QueryRunner runner = new QueryRunner(JDBCUtil02.getDataSource());

String sql = "select count(*) from t_user where username =?";
runner.query(sql, new ScalarHandler(), username);
​
Long result = (Long) runner.query(sql, new ScalarHandler(), username);
return result > 0 ;
}

}

jsp页面显示
        function checkUserName() {
//获取输入框的值 document 整个网页
var name = document.getElementById("name").value; // value value() val val()
//1. 创建对象
var request = ajaxFunction();

//2. 发送请求
request.open("POST" ,"/day16/CheckUserNameServlet" , true );

//注册状态改变监听,获取服务器传送过来的数据
request.onreadystatechange = function(){

if(request.readyState == 4 && request.status == 200){
//alert(request.responseText);
var data = request.responseText;
if(data == 1){
//alert("用户名已存在");
document.getElementById("span01").innerHTML = "<font color='red'>用户名已存在!</font>";
}else{
document.getElementById("span01").innerHTML = "<font color='green'>用户名可用!</font>";
//alert("用户名未存在");
}
}

}

request.setRequestHeader("Content-type","application/x-www-form-urlencoded");
request.send("name="+name);
}

JQuery
● 是什么?
javascript 的代码框架。
● 有什么用?
简化代码,提高效率。
● 核心
write less do more , 写得更少,做的更多。

load
使用JQuery执行load方法

有两次刷新, 先走 onClick的方法,取到数据回来之后,赋值显示。 接着 走 href=”“的路径,但是这个属性没有给值,所以会把当前的页面重新再刷新一次。所以导致看不见值。
//找到这个元素, 去执行加载的动作, 加载/day16/DemoServlet02 , 得到的数据,赋值显示
(“#aaa”).load(“/day16/DemoServlet02” , function(responseText , statusTXT , xhr) {  
//找到id为text01的元素, 设置它的value属性值为 responseText 对应的值
(“#aaa”).load(“/day16/DemoServlet02” , function(responseText , statusTXT , xhr) {  //找到id为text01的元素, 设置它的value属性值为 responseText 对应的值
(“#aaa”).val(responseText);
});

Get
.get(“/day16/DemoServlet02” , function(data ,status) { .get(“/day16/DemoServlet02” , function(data ,status) { (“#div01”).text(data);
});
赋值显示
● val(“aa”);
只能放那些标签带有value属性
● html(“aa”); —写html代码
● text(“aa”);
其实没有什么区别,如果想针对这分数据做html样式处理,那么只能用html()

load & get

● load
(“#元素id”).load(url地址); (“#元素id”).load(url地址); (“#div1”).load(serlvet); —> 使用的get请求,回来赋值的时候, 使用text();去赋值
● get
语法格式 : .get(URL,callback);使 . g e t ( U R L , c a l l b a c k ) ; 使 用 案 例 : .get(“/day16/DemoServlet02” , function(data ,status) {
(“#div01”).text(data);  
});  
  ● post  
语法格式:
(“#div01”).text(data);  });    ● post  语法格式:
.post(URL,data,callback);
function post() {
.post(“/day16/DemoServlet02”, {name:”zhangsan”,age:18},function(data,status) {  
//想要放数据到div里面去。 — 找到div
.post(“/day16/DemoServlet02”, {name:”zhangsan”,age:18},function(data,status) {  //想要放数据到div里面去。 — 找到div
(“#div01”).html(data);
});
}

使用JQuery去实现校验用户名
function checkUserName() {
//1. 获取输入框的内容
var name = $(“#name”).val();

//2. 发送请求
.post(“/day16/CheckUserNameServlet” , {name:name} , function(data , status){  
//alert(data);  
if(data == 1){//用户名存在  
//alert(“用户名存在”);
.post(“/day16/CheckUserNameServlet” , {name:name} , function(data , status){  //alert(data);  if(data == 1){//用户名存在  //alert(“用户名存在”);
(“#span01”).html(“用户名已被注册“);
}else{
//alert(“用户名可用”);
$(“#span01”).html(“用户名可以使用“);
}
} );
//3. 输出响应的数据到页面上。
}

实现百度搜索提示

搭建环境

  1. 定义首页
<body>  <center>    <h2></h2>   
    <input type="text" name="word" id="word" style="width: 600px ; height: 50px  ;font-size: 20px;">    
        <input type="button" value="黑马一下"  style="height: 55px ; width: 100px ; ">      
</div>
</center>
</body>
  1. 定义数据库
捕获键盘弹起
$(function(){	$("#word").keyup(function() {       alert("键盘弹起了..");   })});

JS请求
$(function(){
$("#word").keyup(function() {
//2。 获取输入框的值
//var word = $("#word").val();
//this 对应就是执行这个方法的那个对象, $("#word")
var word = $(this).val();
​
if(word == ""){
$("#div01").hide();
}else{
//3. 请求数据。
$.post("find",{word:word} ,function(data , status){
//alert(data);
$("#div01").show();
$("#div01").html(data);
});
}
})
});

Servlet代码

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
​
request.setCharacterEncoding("utf-8");
try {
//1. 先获取参数
String word = request.getParameter("word");
System.out.println("word="+word);

//2. 让dao执行查询
WordsDao dao = new WordsDaoImpl();
List<WordBean> list = dao.findWords(word);

for (WordBean wordBean : list) {
System.out.println("==="+wordBean.toString());
}

request.setAttribute("list", list);

//3. 返回数据
response.setContentType("text/html;charset=utf-8");
//response.getWriter().write("数据是:");
request.getRequestDispatcher("list.jsp").forward(request, response);
} catch (SQLException e) {
e.printStackTrace();
}

}

list.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
  pageEncoding="UTF-8"%>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%><table style="width: 100%">         <c:forEach items="${list }" var="wordBean">				<tr>					<td>${wordBean.words}</td>                </tr>           </c:forEach>        </table>

使用JQuery实现 省市联动

环境准备
1. 准备数据库
2 。 准备页面

<script type="text/javascript" src="js/jquery-1.11.3.min.js"></script>
<script type="text/javascript" src="js/city.js"></script>
</head>
<body>
省份: <select name="province" id ="province">
<option value="" >-请选择 -
<option value="1" >广东
<option value="2" >湖南
<option value="3" >湖北
<option value="4" >四川
</select>
城市:
<select name="city" id="city">
<option value="" >-请选择 -
</select>
</body>

XStream的使用
//3. 返回数据。手动拼 ---> XStream 转化 bean对象成 xml
XStream xStream = new XStream();

//想把id做成属性
xStream.useAttributeFor(CityBean.class, "id");

//设置别名
xStream.alias("city", CityBean.class);

//转化一个对象成xml字符串
String xml = xStream.toXML(list);

JS代码
$(function() {
//1。找到省份的元素
$("#province").change(function() {
//2. 一旦里面的值发生了改变,那么就去请求该省份的城市数据
//$("#province").varl();
var pid = $(this).val();

/*<list>
<city>
<id>1<id>
<pid>1</pid>
<cname>深圳</cname>
</city>
<city >
<id>2<id>
<pid>1</pid>
<cname>东莞</cname>
</city>
</list>*/

$.post( "CityServlet",{pid:pid} ,function(data,status){
//alert("回来数据了:"+data);

//先清空以前的值:
$("#city").html("<option value='' >-请选择-")
//遍历:
//从data数据里面找出所有的city , 然后遍历所有的city。
//遍历一个city,就执行一次function方法
$(data).find("city").each(function() {

//遍历出来的每一个city,取它的孩子。 id , cname
var id = $(this).children("id").text();
var cname = $(this).children("cname").text();

$("#city").append("<option value='"+id+"' >"+cname)
});
} );

});
});

服务器和客户端数据传输的方式

xml
<list>          <city>              <id>1<id>               <pid>1</pid>                <cname>深圳</cname>           </city>         <city >             <id>2<id>               <pid>1</pid>                <cname>东莞</cname>           </city>     </list>
  ● json
阅读性更好 、 容量更小。
{"name":"aaa" , "age":19}
把javaBean 转化成 json数据
​
//3. 把list ---> json数据
//JSONArray ---> 变成数组 , 集合 []
//JSONObject ---> 变成简单的数据 { name : zhangsan , age:18}

JSONArray jsonArray = JSONArray.fromObject(list);
String json = jsonArray.toString();

使用json格式数据显示省市联动效果
serlvet代码:
​
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
​
try {
//1. 获取参数
int pid = Integer.parseInt(request.getParameter("pid"));

//2 找出所有的城市
CityDao dao = new CityDaoImpl();
List<CityBean> list = dao.findCity(pid);

//3. 把list ---> json数据
//JSONArray ---> 变成数组 , 集合 []
//JSONObject ---> 变成简单的数据 { name : zhangsan , age:18}

JSONArray jsonArray = JSONArray.fromObject(list);
String json = jsonArray.toString();
response.setContentType("text/html;charset=utf-8");
response.getWriter().write(json);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
};
}

js代码

    $(function() {
        //1。找到省份的元素
        $("#province").change(function() {
            //2. 一旦里面的值发生了改变,那么就去请求该省份的城市数据
            //$("#province").varl();
            var pid = $(this).val();

            /*[
                {
                    "cname": "深圳",
                    "id": 1,
                    "pid": 1
                },
                {
                    "cname": "东莞",
                    "id": 2,
                    "pid": 1
                }
                ...
            ]*/
            $.post( "CityServlet02",{pid:pid} ,function(data,status){

                //先清空
                $("#city").html("<option value='' >-请选择-");
                //再遍历,追加
                $(data).each(function(index , c) {
                    $("#city").append("<option value='"+c.id+"' >"+c.cname)
                });
            },"json" );

        });
    });

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值