Ajax的全称:Asynchronous JavaScript And XML(异步的 JavaScript 和 XML)。

Ajax不是某种编程语言,是一种在无需重新加载整个网页的情况下能够更新部分网页的技术。

如何实现Ajax技术(要有这三个方面):

1、运用HTML和CSS来实现页面,表达信息;

2、运用XMLHttpRequest和web服务器进行数据的异步交换;

3、运用JavaScript操作DOM,实现动态局部刷新。

创建XMLHttpRequest对象:

var request = new XMLHttpRequest();

如何兼容IE5、IE6甚至更早的版本?

HTTP请求:

什么是HTTP:http是计算机通过网络进行通信的规则。

HTTP是一种无状态的协议(无状态协议指的是浏览器与服务器不建立持久的连接)。

一个完整的http请求过程,通常有下面7个步骤:

  1、建立TCP连接

  2、web浏览器向web服务器发送请求命令

  3、web浏览器发送请求头信息

  4、web服务器应答

  5、web服务器发送应答头信息

  6、web服务器向浏览器发送数据

  7、web服务器关闭TCP连接

HTTP请求

一个HTTP请求一般由四部分组成:

  1、HTTP请求的方法或动作,比如是GET还是POST请求

  2、正在请求的URL,总得知道请求的地址是什么吧

  3、请求头,包含一些客户端环境信息,身份验证信息等

  4、请求体,也就是请求正文,请求正文中可以包含客户提交的查询字符串信息,表单信息等等

  一个典型的请求如下:

  

GET:一般用于信息获取

  使用URL传递参数

  对所发送的信息数量也有限制,一般在2000个字符

POST:一般用于修改服务器上的资源

  对所发送的信息数量无限制

一个HTTP响应一般由三部分组成

  1、一个数字和文字组成的状态码,用来显示请求是成功还是失败

  2、响应头,响应头和请求头一样包含许多有用的信息,例如服务器类型,日期时间,内容类型和长度等

  3、响应体,也就是响应正文

  一个典型的响应内容如下:

  

HTTP状态码一般由3位数字构成,其中首位数字定义了状态码的类型:

  1XX 信息类,表示收到web浏览器请求,正在进一步处理中

  2XX 成功,表示用户请求被正确接收,理解和处理,例如200 OK

  3XX 重定向,表示请求没有成功,客户必须采取进一步的动作

  4XX 客户端错误,表示客户端提交的请求有错误,例如404 NOT Found,意味着请求中所引用的文档不存在

  5XX 服务器错误,表示服务器不能完成对请求的处理,例如500

XMLHttpRequest发送请求

open(method,url,async)

  method:get/post 不区分大小写

  url:请求地址  

  async:同步或者异步,true为异步处理,false为同步请求,一般默认为异步请求

send(string)

  一般get不填参数,post要填参数

  

XMLHttpRequest取得响应

获取响应值:

  responseText:获得字符串形式的响应数据

  responseXML:获得XML形式的响应数据

  status和statusText:以数字和文本形式返回HTTP状态码

  getAllResponseHeader():获取所有的响应报头

  getResponseHeader():查询响应中的某个字段的值

在响应返回成功时得到通知:

  readyState属性:

    0:请求未初始化,open还没有调用

    1:服务器连接已建立,open已经调用了

    2:请求已接收,也就是接收到头信息了

    3:请求处理中,也就是接收到响应主体了

    4:请求已完成,且响应已就绪,也就是响应完成了

    如果我们想知道服务器响应有没有成功,就需要监听以上的属性值变化

    监听方法:

    

  以上概念实例化代码如下:

  

三、jQuery--Ajax基础--Ajax全接触--Ajax在JS中的应用的更多相关文章

  1. 11月10日上午ajax基础知识、用ajax做登录页面、用ajax验证用户名是否可用、ajax动态调用数据库

    1.ajax的基础知识 ajax是结合了jquery.php等几种技术延伸出来的综合运用的技术,不是新的内容.ajax也是写在<script>标签里面的. 如果使用ajax一定是要有1个处 ...

  2. ajax基础知识、用ajax做登录页面、用ajax验证用户名是否可用、ajax动态调用数据库

    1.ajax的基础知识 ajax是结合了jquery.php等几种技术延伸出来的综合运用的技术,不是新的内容.ajax也是写在<script>标签里面的. 如果使用ajax一定是要有1个处 ...

  3. 14.ajax基础知识、用ajax做登录页面、用ajax验证用户名是否可用、ajax动态调用数据库

    1.ajax的基础知识 ajax是结合了jquery.php等几种技术延伸出来的综合运用的技术,不是新的内容.ajax也是写在<script>标签里面的. 如果使用ajax一定是要有1个处 ...

  4. ajax异步处理时,如何在JS中获取从Servlet或者Action中session,request

    ssh项目中,我需要登陆某个页面(如a.jsp),通过onblur()鼠标失去焦点后来触发js函数(函数是ajax请求)请求到相应的action,处理完成后将数据存放到session对象里面,然后在a ...

  5. jQuery 对AMD的支持(Require.js中如何使用jQuery)

    AMD 模块 AMD(异步模块定义,Asynchronous Module Definition)格式总体的目标是为现在的开发者提供一个可用的模块化 JavaScript 的解决方案. AMD 模块格 ...

  6. 三、jQuery--jQuery基础--jQuery基础课程--第8章 jQuery 实现Ajax应用

    1.使用load()方法异步请求数据 使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为:load(url,[data],[callback]) ...

  7. jQuery基础---Ajax基础教程(二)

    jQuery基础---Ajax进阶 内容提纲: 1.加载请求 2.错误处理 3.请求全局事件 4.JSON 和 JSONP 5.jqXHR 对象 发文不易,转载请注明出处! 在 Ajax 基础一篇中, ...

  8. jQuery基础---Ajax基础教程

    jQuery基础---Ajax基础 内容提纲: 1.Ajax 概述 2.load()方法 3.$.get()和$.post() 4.$.getScript()和$.getJSON() 5.$.ajax ...

  9. 史上最全的Ajax基础详解

    同步请求和异步请求 先解释一下同步和异步的概念: 同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式. 异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯 ...

随机推荐

  1. 如何在 CentOS 7 用 cPanel 配置 Nginx 反向代理

    导读 Nginx 是最快和最强大的 Web 服务器之一,以其高性能和低资源占用率而闻名.它既可以被安装为一个独立的 Web 服务器,也可以安装成反向代理 Web 服务器.在这篇文章,我将讨论在安装了 ...

  2. MySQL分配角色权限

    1.创建新用户 通过root用户登录之后创建 >> grant all privileges on *.* to testuser@localhost identified by &quo ...

  3. java文件和文件夹复制、删除、移动操作

    java文件和文件夹复制.删除.移动操作 import java.io.File; import java.io.FileInputStream; import java.io.FileOutputS ...

  4. Python分割list

    对于一个很大的列表,例如有超过一万个元素的列表,假如需要对列表中的每一个元素都进行一个复杂且耗时的计算,用单线程处理起来会很慢,这时有必要利用多线程进行处理,处理之前首先需要对大的列表进行分割,分割成 ...

  5. js的工作原理

    JavaScript就是所谓的客户端脚本语言,是一种在互联网浏览器(浏览器也称为Web客户端,因为它连接到Web服务器上,以下载页面)内部运行的计算机编程语言. 也就是说,如果一个网页里有js代码,那 ...

  6. Java中对List集合内的元素进行顺序、倒序、随机排序的示例代码

    import java.util.Collections; import java.util.LinkedList; import java.util.List; public class Test ...

  7. ios UITextView 计算文字内容大小

    先设置好 textView的内容文字,再调用以下代码,就能够得到文字内容的size,其中参数表示最大的size的尺寸,通常,高度应该不限制,宽度是控件的宽度. let newSize = statem ...

  8. qq开放平台测试

    2015年3月10日 11:29:56 QQ API对一些链接的curl请求时, 有https, 所以需要安装openssl:  Linux上要安装openssl #yum -y install op ...

  9. Linux下安装Django

    Django是基于Python开发的免费的开源网站框架,也是python web开发中重量级的web框架,可以用于快速搭建高性能并且优雅的网站! 下面以Fedora为例安装Django,最新Fedor ...

  10. java视频转码博客

    一下为找到的资料地址 http://lichen.blog.51cto.com/697816/162124 http://www.cnblogs.com/live365wang/archive/201 ...