Ajax详细解释

Ajax概述

1.同步与异步

  • 同步:客户端与服务器端的请求与响应是一个过程的,也就是说在过程完成前客户端都处于等待卡死状态
  • 异步:客户端发送请求,无论服务器是否响应,客户端都可以随意做其他事情。

2.Ajax的运行原理

页面发起请求,会将请求发送给浏览器内核中Ajax引擎,Ajax引擎会提交请求到服务端,在这段时间里,客户端可以任意进行任意操作,直到服务器端将数据返回给Ajax引擎后,会触发你设置的事件,从而执行自定义的js罗技代码完成某种页面功能。

js原生的ajax

js原生的Ajax其实就是围绕浏览器内置的Ajax引擎对象进行开发的,要使用js原生的Ajax完成异步操作,需要如下步骤

  1. 创建Ajax引擎对象
  2. 为Ajax引擎对象绑定监听(监听服务器已将数据响应给引擎)
  3. 绑定提交地址
  4. 发送请求
  5. 接受响应数据

index.html

<!DOCTYPE HTML>
<html>
  <head>
    <title>index</title>
    <meta http-equiv="pragma" content="no-cache">
    <meta http-equiv="cache-control" content="no-cache">
    <meta http-equiv="expires" content="0">    
    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    <meta http-equiv="description" content="This is my page">
    <!--
    <link rel="stylesheet" type="text/css" href="styles.css">
    -->
    <script type="text/javascript">
        function fn1(){
            // 1.创建ajax引擎对象 --- 所有的操作都是用过引擎对象
            var xmlHttp;
            // 老版本IE5、IE6使用ActiveXObject引擎
            if(window.XMLHttpRequest){ //判断浏览器是否支持此对象
                xmlHttp = new XMLHttpRequest();
            }else{
                xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
            }
            // 2.绑定监听  --- 监听服务器是否已经返回相应数据
            xmlHttp.onreadystatechange = function(){ 
                if(xmlHttp.readyState==4&&xmlHttp.status==200){
                    // 5.接收响应数据
                    document.getElementById("span1").innerHTML = xmlHttp.responseText;
                }
            }
            // 3.绑定数据 - 参数1请求方式、参数2请求地址、参数3是否异步
            xmlHttp.open("post","AjaxServlet",true);
            // 4.发送请求
            xmlHttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            xmlHttp.send("name=wangsiyuan");
        }
    </script>
  </head>
  <body>
    <input type="button" value="异步访问服务器" onclick="fn1()">
    <span id="span1"></span>
  </body>
</html>
属性 描述
onreadystatechange 存储函数(或函数名),每当readyState属性改变时,就会调用该函数
readyState 存有XMLHttpRequest的状态。从0到4的变化(0:请求未初始化 1:服务器连接已建立 2:请求已处理 3:请求处理中 4:请求已完成,且响应已就绪)
status 200:"OK" 404:"页面未找到"

AjaxServlet.java

package top.code666.ajax01;

import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class AjaxServlet extends HttpServlet {
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        String name = (String) request.getParameter("name");
        response.getWriter().write(Math.random()+name);
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        this.doGet(request, response);
    }
}

运行结果:

image

JQuery的Ajax技术(重点)

1.jQuery的get、post方式

  • $.get(url,[data],[callback],[type])
  • $.post(url,[data],[callback],[type])
    url:代表请求的服务器地址
    data:代表请求服务端的数据(可以是key=value形式也可以是json格式)
    callback:表示服务器端成功响应所触发的函数(只有正常成功返回才执行)
    type:表示服务器端返回的数据类型(jQuery会根据指定的类型自动类型转换)
    常见的返回类型:text、json、html等
// 这里只贴js代码
<script>
    function fn1(){
        // get异步访问
        $.get(
            "/project/ajaxProject", //url地址
            {"name":"zhangsan","age":22}, //发送给服务器的数据
            function(data){ //成功后的回调方法
                   alert(data);
            },
            "text" //返回类型
        );
    }

    function fn1(){
        // post异步访问
        $.post(
            "/project/ajaxProject", //url地址
            {"name":"zhangsan","age":22}, //发送给服务器的数据
            function(data){ //成功后的回调方法
                 //{\"name\":\"tom\",\"age\":21}
                   alert(data.name);
            },
            "json" //返回类型
        );
    }
</script>

注意:post方法传输中文到服务端不用考虑乱码问题,get方法需要考虑乱码问题

2.jQuery的ajax方式

$.ajax({option1:value1,option2:value2...});
常用的option有如下:

  • async:是否异步,默认是true代表异步
  • data:发送到服务器的参数,建议使用json格式
  • dataType:服务器端返回的数据类型,常用的text和json
  • success:成功响应执行的函数,对应的类型是function类型
  • type:请求方式,POST/GET
  • url:请求服务端地址
<script>
    function fn3(){
            $.ajax({
                url:"/project/ajaxProject",
                async:true,
                type:"POST",
                data:{"name":"tom","age":22},
                success:function(data){
                    alert(data.name);
                },
                error:function(){
                    alert("请求失败");
                },
                dataType:"json"
            });
        }
</script>

觉得还行可以点个星星哦

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,158评论 4 370
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,600评论 1 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,785评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,655评论 0 220
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,075评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,002评论 1 225
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,146评论 2 318
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,918评论 0 211
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,671评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,838评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,318评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,636评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,343评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,187评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,982评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,126评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,934评论 2 279

推荐阅读更多精彩内容

  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,117评论 1 45
  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 3,056评论 0 7
  • 27、移动端响应式布局开发 响应式布局开发 1、什么是响应式布局开发?把我们开发完成的产品,能够让其适配不同的设备...
    萌妹撒阅读 1,019评论 0 0
  • 一:什么是闭包?闭包的用处? (1)闭包就是能够读取其他函数内部变量的函数。在本质上,闭包就 是将函数内部和函数外...
    xuguibin阅读 9,196评论 1 52
  • 认识老马,是乒乓球带来的机缘。那天约了一起打乒乓球的,结果小贱那小子临时有事来不了,也没发个微信告诉我。我就早早地...
    遇见英语阅读 688评论 1 3