Ajax异步请求

Stella981
• 阅读 755
Ajax 即"Asynchronous Javascript And XML"(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术。Ajax = 异步 JavaScript 和 XML(标准通用标记语言的子集)。通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。传统的网页(不使用 Ajax)如果需要更新内容,必须重载整个网页页面。

  简而言之:一项通过js技术发送异步请求 的技术。

Ajax技术的核心是XMLHttpRequest。Ajax就是通过XMLHttpRequest对象来发送异步的请求。

1.js原生Ajax的开发步骤

  1. 创建Ajax引擎对象--XMLHttpRequest对象;

  2. 为XMLHttpRequest对象绑定监听(监听服务器,将数据响应给引擎);

  3. 绑定提交地址;

  4. 发送请求;

  5. 接收响应数据;

2.js原生的Ajax代码实现

【案例】js原生的Ajax演示

【需求】

  1. 点击页面按钮发送请求到后台Servlet;

  2. 后台Servlet接收数据后,给出响应;

  3. 页面接收响应数据;

demo1.html

<!--demo1.html-->

<html>
  <head>
    <title></title>
  </head>
  <body>
        <button id="btn" onclick="sendAjax();">点击后,发送Ajax请求</button>
  </body>
<script>
    function sendAjax() {
        //js原生的Ajax实现

        //1.创建XMLHttpRequest对象
        var xhr = new XMLHttpRequest();

        //2.给XMLHttpRequest对象绑定监听
        xhr.onreadystatechange = function () {
            if(xhr.readyState == 4 && xhr.status == 200) {
                //5.接收响应
                alert(xhr.responseText);
            }
        }
        //3.绑定提交地址
        /**
         * GET:请求方式;
         * url:请求地址
         * flag: true--异步请求,false--同步请求
         */
        xhr.open("GET", "/ajaxServlet", true);
        //4.发送请求
        xhr.send();
    }
</script>
</html>

Servlet代码

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;


@WebServlet(name = "AjaxDemo", urlPatterns = "/ajaxServlet")
public class AjaxDemo extends HttpServlet {

    /**
     * 接收ajax请求
     */
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().println("传智播客");
    }
}

jQuery的Ajax

js原生的Ajax虽然能够向后台发送请求,但是太过繁琐。jQuery对原生的Ajax方法进行了封装,下面是开发中使用的比较多的3种jQuery的Ajax实现。

Ajax异步请求

【注意】以上3种方法都是基于jQuery实现的,所以在使用之前必须先导入jquery的类库。

1、GET请求

1.1、GET请求方式概述

​ 通过远程HTTP GET请求发送请求。这是一个简单的GET请求,以取代复杂的$.ajax。请求成功时可调用回调函数。如需复杂的ajax请求参数设置,请使用$.ajax

1.2、GET请求的语法格式

$.get(url,[data],[callback],[type])

其中,参数说明如下:

参数

说明

url

请求地址

data

发送给服务器端的请求参数,格式:
方式一:key=value&key=value
方式二:{key:value,key:value...}

callback

回调函数:当请求成功后触发的函数

type

返回参数类型:取值可以是xml, html, script, json, text, _defaul等

1.3、GET请求案例

【案例】GET请求案例

【需求】

  1. 点击按钮后,数据"name='张三',age=18"发送到后台服务器;

  2. 后台接收到数据后,响应"OK";

demo2.html

<!--demo2.html-->
<html>
<head>
    <title>Title</title>
    <script src="js/jquery-3.3.1.js"></script>
</head>
<body>
<button onclick="ajaxGetFn();">send</button>
</body>
<script>
    //按钮单击事件
    function ajaxGetFn() {

        //Ajax的GET请求:
        //方式一:key=value&key=value形式传值
        // $.get("/getDemo","name='张三'&age=18",function (res) {
        //     //处理响应数据
        //     alert(res);
        // },"text");

        //方式二:{key:value,key:value}形式传值
        $.get("/getDemo",{"name":"张三","age":18},function (res) {
            //处理响应数据
            alert(res);
        },"text");

    }
</script>
</html>

servlet代码

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet(name = "GetDemoServlet", urlPatterns = "/getDemo")
public class GetDemoServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //处理post请求和响应乱码问题
        response.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        doGet(request,response);
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            //获取请求参数
        String name = request.getParameter("name");
        String age = request.getParameter("age");
        response.setContentType("text/html; charset=utf-8");
        response.getWriter().print("ok!  name="+name+"; age="+age);
    }
}

2、POST请求

2.1、POST请求方式概述

​ 通过远程 HTTP POST 请求载入信息。这是一个简单的 POST 请求功能,如需复杂的ajax参数设置请使用$.ajax。

2.2、POST请求的语法格式

$.post(url, [data], [callback], [type])其中,参数说明如下:

参数

说明

url

请求的服务器端url地址

data

发送给服务器端的请求参数,格式可以是key=value,也可以是js对象

callback

当请求成功后的回调函数,可以在函数体中编写我们的逻辑代码

type

预期的返回数据的类型,取值可以是 xml, html, script, json, text, _defaul等

2.3、POST请求案例

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <script src="js/jquery-3.3.1.js"></script>
</head>
<body>

    <button onclick="ajaxPostFn();"> Ajax的post请求,发送数据到后台</button>
</body>

    <script>
        //按钮单击事件
        function ajaxPostFn(){

            $.post("/postDemo",{"name":"李四","age":13},function(res){
                alert(res)
            });

        }
    </script>
</html>

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;


@WebServlet(name = "PostDemoServlet", urlPatterns = "/postDemo")
public class PostDemoServlet extends HttpServlet {

    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取请求参数
        String name = request.getParameter("name");
        String age = request.getParameter("age");
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().println("ok! name="+name+";age="+age);

    }


    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //处理post请求和响应乱码问题
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        doGet(request, response);
    }
}

3、Ajax请求

3.1 Ajax请求概述

​ 通过 HTTP 请求加载远程数据。jQuery 底层 A JAX 实现。简单易用的高层实现见get和post方法。$.ajax()方法可以更加详细的设置底层的参数。

3.2 A JAX请求方式语法

$.ajax([settings])其中,settings是一个js字面量形式的对象,格式是{name:value,name:value... ...},常用的name属性名如下:

Ajax异步请求

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
    <script src="js/jquery-3.3.1.js"></script>
</head>
<body>
    <button onclick="ajaxDemoFn()">Ajax请求</button>
</body>
    <script>
        /*
        * 绑定事件
        * */
        function  ajaxDemoFn() {
            $.ajax({
                url:"/ajaxDemo",
                data:{"name":"哈哈哈","age":4},
                async:true,
                type:"GET",
                dataType:"text",
                success:function (succRes) {
                    alert(succRes);
                },
                error:function (errorRes) {
                    alert("出现异常了")
                }
            });
        }
    </script>
</html>

package com.heima.ajax;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * @author buguniao
 * @desc
 * @date 2018-07-02:16:40
 * @copy 本项目版权归java31期所有,未经许可不得私自复制,否则,要承当法律责任
 */
@WebServlet(name = "AjaxDemo", urlPatterns = "/ajaxDemo")
public class AjaxDemo extends HttpServlet {

    /**
     * 接收ajax请求
     */
    @Override
    public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取请求参数
        String name = request.getParameter("name");
        String age = request.getParameter("age");
        response.setContentType("text/html;charset=utf-8");
        response.getWriter().println("ok! name="+name+";age="+age);
    }


    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //处理post请求和响应乱码问题
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        doGet(request, response);
    }
}
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
AjaxPro.dll,asp.net 前台js调用后台方法(无刷新)
1、什么是AjaxAjax是异步Javascript和XML(AsynchronousJavaScriptandXML)的英文缩写。"Ajax"这个名词的发明人是JesseJamesGarrett,而大力推广并且使Ajax技术炙手可热的是Google。Ajax的核心理念在于使用XMLHttpRequest对象发送异步请求。
Stella981 Stella981
3年前
Django的日常
\toc\Django的日常AJAXAJAX简介首先AJAX是一种无需重新加载整个网页的前提下,能够更新部分网页的技术,他并不是一种新的编程语言,而是一种使用现有标准的新方法,是基于原生JavaScript开发的,他可以用于创建快速动态网页.AJAX最大的特点就是局部刷新以及异步提交,局部刷新
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这