一、Ajax的简介

Ajax,异步JavaScript和XML,异步提交,无刷新技术,局部刷新技术

1)传统的客户端与服务器端交互的模式

客户端发送请求直接给服务端,服务接受到请求后进行逻辑运算,最终服务器端会将结果直接响应给客户端。

2)Ajax的客户端与服务端交互模式

客户端发送请求时,不是将请求直接发送给服务器端,是将请求发送客户端ajax引擎,引擎负责帮助客户端提交请求到服务器端,服务器端接受请求进行逻辑运算,最终服务器端会将结果响应给ajax引擎,ajax引擎监听到结果已经返回,通知客户端接收数据。

二、快速入门

<script type="text/javascript">
function fn1() {
//1、创建ajax引擎
var xmlhttp = new XMLHttpRequest();
//alert(xmlhttp.readyState);
//2、设置监听
xmlhttp.onreadystatechange = function() {
//5、接受数据 4代表服务器端已经响应数据完毕的状态
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var rondomData = xmlhttp.responseText;
//动态的将是数据设置到span1中
document.getElementById("span1").innerHTML = rondomData;
}
};
//3、绑定地址
xmlhttp.open("GET", "/test/async", false);
//4、发送请求
xmlhttp.send();
}
function fn2() {
//1、创建ajax引擎
var xmlhttp = new XMLHttpRequest();
//alert(xmlhttp.readyState);
//2、设置监听
xmlhttp.onreadystatechange = function() {
//5、接受数据 4代表服务器端已经响应数据完毕的状态
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
var rondomData = xmlhttp.responseText;
//动态的将是数据设置到span1中
document.getElementById("span2").innerHTML = rondomData;
}
};
//3、绑定地址
xmlhttp.open("GET", "/test/async", true);
//4、发送请求
xmlhttp.send();
}
</script> </head>
<body>
<input onclick="alert('xxxxx')" type="button" value="测试按钮">
<br>
<input onclick="fn1()" type="button" value="同步提交">
<span id="span1"></span>
<br>
<input onclick="fn2()" type="button" value="异步提交">
<span id="span2"></span>
<br>
</body>
</html>
<!--实际一般很少会用原生JS这种方式-->

步骤的详解

创建ajax引擎

var xmlhttp = new XMLHttpRequest();(ie6以上都可以)

解决浏览器的兼容性:

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");

}

设置ajax引擎对象的状态监听

监听事件:onreadystatechange = function(){}

ajax引擎的状态:

readyState:数字  不同的数字代表引擎不同的状态

0: 请求未初始化

1: 服务器连接已建立

2: 请求已接收

3: 请求处理中

4: 请求已完成,且响应已就绪 --- 服务端将属性响应给客户端ajax引擎

响应的状态:status ---- 状态码 200 302 304 404 500

当服务器端响应的结果没有问题时 即status=200 才获取数据


绑定地址

open(method,url,async);

其中的参数:

method:请求方式,POST/GET

url:请求服务器资源地址

async:是否异步 true代表异步 false代表同步

注意:仅仅是绑定数据 请求尚未发送

发送请求

send(params);

其中的参数:

params:代表是请求参数 name=zhangsan&password=123

但是,send方法中的参数只有post方式提交时才设置

get提交时 参数携带带url后面

注意:post提交,必须要设置一个请求头

xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");

接受响应数据

在监听的函数中接受数据,接受数据库时,保证ajax引擎的状态是4,保证响应的状态是200

if(xmlhttp.readyState==4&&xmlhttp.status==200){

alert(xmlhttp.responseText);

}

ajax引擎取出数据的方式:

responseText:服务器端返回的是普通字符串

responseXml:服务器端返回是xml(基本不使用了)

三、jquery的ajax操作

load方法

obj.load(url, [data], [callback])

其中的参数:

url:ajax提交时 提交的服务器端的地址

data:请求的数据

callback:服务器端响应后调用的函数(回调函数)

注意:load方法 是jquery对象调用的

get方法

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

其中的参数:

url:提交的地址

data:提交的参数

callback:回调函数

type:声明返回值的类型

xml, html, script, json, text, _default。

post方法

同get方法

ajax方法(个人用这个比较习惯)

$.ajax(options);

其中options代表参数的集合,参数集合的表现方式是json

options是多个参数的json格式

{参数:参数值,参数:参数值...}

常用的参数:

async:是否异步 false/true

data:提交给服务器的参数

dataType:服务端端返回的数据类型

error:出错调用的函数

success:ajax执行成功后调用的函数

type:提交方式

url:提交的地址

json:

json是一种不依赖于任何语言的数据交换格式。

json的三种数据格式:

1)对象格式 {name:value,name:value...}

user对象

private int id = 10;

private String name = “zhangsan”

private String addr = “beijing”

json格式描述user对象:

{“id”:10,”name”:”zhangsan”,”addr”:“beijing”}

注意:在json数据格式中 name类型是字符串,value类型是Object

2)数组格式 [元素,元素,元素...]

元素可以是任何类型,String,int,User

3)组合格式

对象格式与数组格式可以互相嵌套

解析json时一般常用的工具:Gson,fastjson...

一般搜索时商品名补全阿,登陆时的一些提示阿,都会用到AJAX

AJAX的简单梳理的更多相关文章

  1. html --- ajax --- javascript --- 简单的封装

    Ajax的简单封装 Ajax的全称是AsynchronousJavaScriptAndXML 如有疑问请参考:http://zh.wikipedia.org/zh-cn/AJAX 以及传智播客的视频教 ...

  2. 机器学习&数据挖掘笔记(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 作者:tornadomeet 出处:http://www.cnblogs.com/tornadomeet 前言: 找工作时( ...

  3. [转]机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理)

    机器学习&数据挖掘笔记_16(常见面试之机器学习算法思想简单梳理) 转自http://www.cnblogs.com/tornadomeet/p/3395593.html 前言: 找工作时(I ...

  4. MVC3.0+knockout.js+Ajax 实现简单的增删改查

    MVC3.0+knockout.js+Ajax 实现简单的增删改查 自从到北京入职以来就再也没有接触MVC,很多都已经淡忘了,最近一直在看knockout.js 和webAPI,本来打算采用MVC+k ...

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

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

  6. C#正则表达式_简单梳理_Emoji表情字符处理

    A-最近一直有接触到正则表达式,现对其做简单梳理: private const RegexOptions OPTIONS = RegexOptions.IgnoreCase | RegexOption ...

  7. RocketMQ 简单梳理 及 集群部署笔记【转】

    一.RocketMQ 基础知识介绍Apache RocketMQ是阿里开源的一款高性能.高吞吐量.队列模型的消息中间件的分布式消息中间件. 上图是一个典型的消息中间件收发消息的模型,RocketMQ也 ...

  8. Memcached概念、作用、运行原理、特性、不足简单梳理(1)

    大家可能对memcached这种产品早有了解,或者已经应用在自己的网站中了,但是也有一些朋友从来都没有听说过或者使用过.这都没什么关系,本文旨在从各个角度综合的介绍这种产品,尽量深入浅出,如果能对您现 ...

  9. 第107天:Ajax 实现简单的登录效果

    使用 Ajax 实现简单的登录效果 Ajax是一项使局部网页请求服务器信息,而不需整体刷新网页内容的异步更新技术.这使得向服务器请求的数据量大大减少,而且不会因局部的请求失败而影响到整体网页的加载. ...

随机推荐

  1. javaWEB与EL表达式

    EL表达式1. EL是JSP内置的表达式语言!  * jsp2.0开始,不让再使用java脚本,而是使用el表达式和动态标签来替代java脚本!  * EL替代的是<%= ... %>,也 ...

  2. css3圆环闪烁动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. 搭建 redis 3.2.8服务器

    实验环境 redis 3.2.8 + RHEL 7.3 系统 软件下载地址 http://download.redis.io/releases/redis-3.2.8.tar.gz #注意,我的软件包 ...

  4. 原创SQlServer数据库生成简单的说明文档小工具(附源码)

    这是一款简单的数据库文档生成工具,主要实现了SQlServer生成说明文档的小工具,目前不够完善,主要可以把数据库的表以及表的详细字段信息,导出到 Word中,可以方便开发人员了解数据库的信息或写技术 ...

  5. Legendary Items-微软实习生笔试第一题

    题目如下: 这道题难点不仅在于正确理解题意,判断递归条件,更在于用数学方法推出解决公式.因为N最大为1百万,而内存只有256MB, 所以暴力递归肯定会超时,超空间. 不过,我才疏学浅,又没有大量时间去 ...

  6. 老李秘技:loadrunner11是否还支持dblib协议?

    老李秘技:loadrunner11是否还支持dblib协议?   Loadrunner11不再支持Sybase CTLIB 和 DBLIB协议 在loadrunner安装文件中找到*. LRP文件,位 ...

  7. (删)Java线程同步实现二:Lock锁和Condition

    在上篇文章(3.Java多线程总结系列:Java的线程同步实现)中,我们介绍了用synchronized关键字实现线程同步.但在Java中还有一种方式可以实现线程同步,那就是Lock锁. 一.同步锁 ...

  8. WSDL/WebService/SOAP/REST/AXIS/CXF 开放式服务

    WebService是一种数据交换标准.通过WebService标准,你可以把项目中的方法作为接口提供给其他项目使用. 有时候我们习惯性地将具体提供服务的某个方法称为WebService.比如图书系统 ...

  9. 【微信开发】PHP中奖概率经典算法实例

    $arr=array("50","30","20"); //这里简单列出三个数 $pro = array_sum($arr); // 概率数 ...

  10. 自然梯度(Natural Gradient)

    自然梯度(Natural Gradient)