【知了堂学习笔记】ajax工作原理

ajax工作原理

什么是ajax?

  ajax 的全称是Asynchronous JavaScript and XML,其中,Asynchronous 是异步的意思。从全称中就可以看出AJAX = 异步 JavaScript 和 XML。

   AJAX 是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

  使用 AJAX 的应用程序案例比如有:新浪微博、Google 地图、开心网,123rf网站等等

ajax是基于现有的Internet标准,所包含的技术

  1.CSS和XHTML (给数据定义样式)。

  2. DOM(信息交互和动态显示)。

  3.XMLHttpRequest(和服务器进行异步通信)。

  4.avascript(绑定和调用)。

ajax原理和XmlHttpRequest对象

  Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面。这其中最关键的一步就是从服务器获得请求数据。XmlHttpRequest就是javascript可以及时向服务器提出请求和处理响应,从而不阻塞用户。达到无刷新的效果。

  XMLHttpRequest的属性:

    > onreadystatechange:每次状态改变所触发事件的事件处理程序;

    > responseText:从服务器进程返回数据的字符串形式;

    > responseXML:从服务器进程返回的DOM兼容的文档数据对象;

    > status:从服务器返回的数字代码(状态码),比如常见的404(未找到)和200(成功);

    > status Text :伴随状态码的字符串信息;

    > readyState: 对象状态值:

      0 (未初始化) 对象已建立,但尚未初始化,尚未调用open方法;

      1 (初始化) 对象已建立,链接读取中,但尚未调用send方法;

      2 (发送数据) 请求已接收读取,send方法已调用,但是当前的状态及http头未知;

      3 (数据传送中) 已接收部分数据,因为响应及http头不全,这时通过responseBody和responseText获取部分数据会出现错误;

      4 (完成) 数据接收完毕,此时可以通过通过responseXml和responseText获取完整的回应数据。

  由于各浏览器之间存在差异,这个差异主要体现在IE和其它浏览器之间,所以创建一个XMLHttpRequest对象可能需要不同的方法。下面是我创建XMLHttpRequest对象的方法。

//获取显示文本的对象var msg = document.getElementById("msg");
function checkUserFn(){
  //获取要传送的对象的值
  var username = document.getElementById("username").value
  // 1 创建xhr对象(XMLHttpRequest)
  var xhr = null;//创建xhr,初值为空
  //非IE浏览器创建XmlHttpRequest对象
  if(window.XMLHttpRequest){
    xhr = new XMLHttpRequest();
  }
  //IE浏览器创建XmlHttpRequest对象
  if(window.ActiveXObject){
    xhr = new ActiveXObject("Microsoft.XMLHTTP");
  }
  //2 打开ajax链接通道,配置参数(请求方式,请求地址url,同步or异步)。
  xhr.open("POST",url,true);

    xhr.onreadystatechange = function () {
     if (xhr.readyState == 4) {

      msg.innerHTML = "数据正在加载...";

       if (xhr.status == 200) {
          document.write(xhr.responseText);
       }
     }
   }

   //3 发送请求

   xhr.send();
} 

  其中要注意的是

    a、向服务器提交数据的类型;

    b、post和get请求的url地址和传递的参数写法不一样;

   c、传输方式,false为同步,true为异步。默认为true;

  为了增强自己对ajax的理解,写了这篇博文,把我理解的知识也分享给大家,刚开始写,有很多不足,欢迎来吐槽,指出不足,想要更详细了解,可以去http://www.cnblogs.com/mingmingruyuedlut/archive/2011/10/18/2216553.html,很感谢这篇博文博主的详解。

原文地址:https://www.cnblogs.com/SunlIng-52/p/8283068.html

时间: 2024-08-08 09:35:11

【知了堂学习笔记】ajax工作原理的相关文章

[知了堂学习笔记]_初始化顺序

在我们每次new一个对象的时候,对象都会被初始化,但是他们初始化的顺序又是怎样呢?现在我以存在继承与不存在继承的代码给大家演示. 一.对于没有继承的初始化的顺序(静态变量,静态块.构造函数.变量) package test; //没有继承情况下的代码 public class test5 { //静态变量 private static String st="静态变量"; //静态块 static{ System.out.println(st); System.out.println(&

【知了堂学习笔记】Eclipse,Myeclipse连接MySQL数据库和Oracle数据库

一.连接MySQL数据库 1.由于Eclipse,Myeclipse都没有连接MySQL数据的架包,我们需要自行下载MySQL连接架包 mysql-connector(官方链接:http://dev.mysql.com/downloads/connector/j/5.0.html),下载版本最好是最新版. 2.下载好后,复制到你的项目里任何位置,然后右键架包选择 Build path -> add to Build path,然后点击项目的Libraries里的Referenced Librar

[知了堂学习笔记]_纯JS制作《飞机大战》游戏_第1讲(实现思路与游戏界面的实现)

整体效果展示: 一.实现思路 如图,这是我完成该项目的一个逻辑图,也是一个功能模块完成的顺序图. 游戏界面的完成 英雄飞机对象实现,在实现发射子弹方法过程中,又引出了子弹对象并实现.在此时,英雄飞机能进行基本操作了. 敌机对象的实现,并且初步完成了boos出现(30s自动出现).然后又引出了许多方法的处理,如英雄子弹击中敌机和boos,英雄与敌机相撞等等.并一一解决. 随后又设置了一些游戏的参数,如血量,关卡数,等级,积分,必杀,道具对象等等. 最后又完成了一些辅助功能,暂停游戏,继续游戏,退出

aJax学习之Ajax工作原理

转自:http://www.cnblogs.com/mingmingruyuedlut/archive/2011/10/18/2216553.html 在写这篇文章之前,曾经写过一篇关于AJAX技术的随笔,不过涉及到的方面很窄,对AJAX技术的背景.原理.优缺点等各个方面都很少涉及null.这次写这篇文章的背景是因为公司需要对内部程序员做一个培训.项目经理找到了我,并且征询我培训的主题,考虑到之前Javascript.CSS等WEB开发技术都已经讲解过了,所以决定针对AJAX这一块做一个比较系统

[知了堂学习笔记]_Java代码实现MySQL数据库的备份与还原

通常在MySQL数据库的备份和恢复的时候,多是采用在cmd中执行mysql命令来实现. 例如: mysqldump -h127.0.0.1 -uroot -ppass test > d:/test.sql ---备份test数据库到 D 盘 mysql -h127.0.0.1 -uroot -ppass test< test.sql ---将D备份的数据库脚本,恢复到数据库中 更多命令参看:http://www.cnblogs.com/xcxc/archive/2013/01/30/28828

【知了堂学习笔记】java 接口与抽象类

本次主角:抽象类 .接口. 对于皮皮潇这样一类的Java初学者来说,接口和抽象类如果不去花大量的精力与时间是很难弄清楚的,而我也是在最近这周的项目学习中感觉到了我对这两个概念不熟悉,所以导致对一些问题不能理解清楚,然后就去查阅资料对抽象类与接口做了一些总结. 1.抽象类: 抽象类的建立,实在抽象方法之后的,所以想要了解抽象类得先了解抽象方法,抽象方法由名字可以知道它是一种特殊的方法,是抽象的,只有方法的声明,没有具体的实现.所以不能看到它的功能,表现得就很抽象. 抽象方法必须要用abstract

[知了堂学习笔记]_JSON数据操作第2讲(JSON的封装与解析)

上一讲为大家讲了什么是JSON,那么这一讲为大家带来了在WEB项目中JSON的用法,也就是JSON的封装与解析. 此图是数据库中的部分内容 一.JSON封装 所谓的JSON封装,指的是在Servlet中将从数据库得到的数据转化成JSON格式的字符串. 那么什么是JSON格式的字符串? JSON格式的字符串就是指字符串的内容要完全符合JSON数据的格式 这个就是在servlet中输出的已经封装好的JSON格式字符串,在控制台输出的效果. 如何封装 在我自己的WEB中,原本想用原生态的JSON去封装

【知了堂学习笔记】java 正则表达式

本文参考网络上面别人的博客知识产出 正则表达式基础 1.句号 假设你想要找出三个字母的单词,而且这些单词必须以"t"字母开头,以"n"字母结束.另外,假设有一本英文字典,你可以用正则表达式搜索它的全部内容.要构造出这个正则表达式,你可以使用一个通配符--句点符号".".这样,完整的表达式就是"t.n",它匹配"tan"."ten"."tin"和"ton&qu

【知了堂学习笔记】java中常用集合的理解

最近学习了java中常用集合类的一些知识,在这里作为一只小白,我来谈谈我的理解,顺带总结知识点. 引入:在没有接触之前,听到集合,给我感觉是想到了数学中的集合一样,里面存放着一个一个的元素.其实不然,这个集合也就差不多,是用来存放元素的容器. Java中的集合类包含的内容很多而且很重要,很多数据的存储和处理(排序,去重,筛选等)都需要通过集合类来完成. 今天我要谈的主要是,如下图所示: 1.Collection Collection是最基本的集合类型,若要检查Collection中的元素,可以使