第21章  AJAX

AJAX技术的核心是XMLHttpRequest对象。可以使用XHR对象取得新数据,然后通过DOM将新数据插入到页面中。无需刷新页面即可从服务器获得数据。

1、XHR对象。

如果只想支持IE7+,那么可以直接使用XHR构造函数。

如果支持IE6:

function createXHR(){
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
return new XMLHttpRequest();
}
else
{// code for IE6, IE5
return new ActiveXObject("Microsoft.XMLHTTP");
}
else
{
throw new Error("No XHR object available.");
}
}

1、XHR的用法

使用XHR对象,要调用的第一个方法是open()

xhr.open("get","example.php",false);

调用这个方法不会真正发送请求,只是启动一个请求以备发送。

要发送特定的请求,必须调用send()方法

xhr.open("get","example.php",false);
xhr.send(null);

这次请求是同步的,JS代码会等到服务器响应之后再继续执行。接收到响应后,响应的数据会自动填充XHR对象的属性。

①responseText:作为响应主体被返回的文本;

②responseXML:如果相应的内容类型是text/xml或application/xml,这个属性将保存包含着相应数据的XML DOM文档;非XML数据,值为null。

③status:相应的HTTP状态。

④statusText:HTTP状态说明。

在接收到响应后,第一步是检查status属性,以确响应已经成功返回。

以上为发送同步请求,异步请求能让JS继续执行而不必等待响应。此时可以检测XHR对象的readyState属性,表示请求/相应过程的当前活动阶段。

①0:未初始化。尚未调用open()方法;

②1:启动。已open(),未send();

③2:发送。已send(),未收到响应;

④3:接收。已收到部分响应数据;

⑤:完成。可以使用了。

readyState改变时都会触发一次readystatechange事件。必须在调用open()之前指定onreadystatechange事件处理程序才能保证跨浏览器兼容性。

2、HTTP头部信息

使用setRequestHeader()方法可以设置自定义请求头部信息,必须在open()后和send()前调用。

getResponseHeader()和getAllResponseHeaders()可获取头部信息。

3、GET请求。

GET是最常见的请求类型,常用于向服务器查询某些信息。查询字符串必须经过encodeURIComponent()进行正确的编码。

4、POST请求。

通常向服务器发送应该被保存的数据。

第一步open()初始化,第二部向send()传入某些数据。模仿表单提交P577.

POST请求比GET请求消耗资源。

2、XHR 2级

1、FormData。序列化表单。

xhr.open("post","postexample.php",true);
var form=document.getElementById("user-info");
xhr.send(new FormData(form));

2、超时设定

timeout属性。请求在多少毫秒后终止并触发timeout事件。(IE8+)

3、overrideMimeType()方法

重写响应的MIME类型。在send()前调用。

3、进度事件。

Progress Events规范,六个进度事件

①loadstart②progress③error④abort⑤load⑥loadend。每个请求都是从出发loadstart开始,接下来是一个或多个progress,然后出发error/abort/load中的一个,然后出发loadend结束。

progress事件,可用来做进度指示器。onprogress事件处理程序接收一个event对象,target属性是XHR对象,额外三个属性:lengthComputable——进度信息是否可用、position——已接收字节数、totalSize——根据响应头部确定的预期字节数。必须在open()之前添加onprogress事件处理程序。

js-JavaScript高级程序设计学习笔记17的更多相关文章

  1. JavaScript高级程序设计---学习笔记(一)

    今天,2017.3.17开始利用课余时间仔细学习<JavaScript高级程序设计>,将需要掌握的知识点记录下来,争取把书里的所有代码敲一遍并掌握. 1.标识符命名最好是第一个字母小写,剩 ...

  2. javascript高级程序设计学习笔记

    javascript高级程序设计,当枕头书已经好久了~zz  现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ...

  3. javascript 高级程序设计 学习笔记

    <!--<script> // 异步请求封装 IE6即以上浏览器 // ajax(url,fnSucc,selectID,fnFaild) //url 请求地址 //fnSucc 异 ...

  4. JavaScript高级程序设计---学习笔记(二)

    面向对象程序设计1.属性类型.定义多属性.读取属性特性对象的属性在创建时都带有一些特征值,JavaScript通过这些特征值来定义它们的行为.这些特性是为了实现JavaScript引擎用的,因此不能直 ...

  5. JavaScript高级程序设计学习笔记--DOM

    DOM(文档对象模型)是针对HTML和XML文档的一个API(应用程序接口). Document类型 文档的子节点 虽然DOM标准规定Document节点的子节点可以是DocumentType,Ele ...

  6. Javascript高级程序设计学习笔记一

    看完w3school的javascript的概念,有点基础,开始红皮书的路程,今晚总结前二章的心得. 第一章:javascript简介 重点是javascript的实现是由 ECMAScript(核心 ...

  7. JavaScript高级程序设计学习笔记--面向对象的程序设计(二)-- 继承

    相关文章: 面向对象的程序设计(一) — 创建对象 http://www.cnblogs.com/blackwood/archive/2013/04/24/3039523.html 继承 继承是OO语 ...

  8. JavaScript高级程序设计学习笔记第十章--DOM

    1.DOM:文档对象模型,是针对 HTML 和 XML 文档的一个 API(应用程序编程接口). 2.DOM 可以将任何 HTML 或 XML 文档描绘成一个由多层节点构成的结构. 3.文档节点是每个 ...

  9. JavaScript高级程序设计学习笔记第一章

    作为学习javascript的小白,为了督促自己读书,写下自己在读书时的提炼的关键点. 第一章: 1.JavaScript简史:Netscape Navigator中的JavaScript与Inter ...

  10. JavaScript高级程序设计学习笔记之事件

    1.事件流 事件流描述的是从页面中接收事件的顺序. 事件冒泡 IE的事件流叫做事件冒泡(event bubbling),即事件开始时由最具体的元素(文档中嵌套层次最深的那个节点)接收,然后逐级向上传播 ...

随机推荐

  1. Centos6 安装 Redis

    先确认gcc和tcl已经安装 sudo yum install gcc-c++ sudo yum install tcl 解压, 编译和安装 .tar.gz /usr/src/ cd /usr/src ...

  2. 学习C++.Primer.Plus 4 复合类型

    本章介绍的有复合类型有: 数组. 字符串. 结构. 共用体. 指针 数组: 声明数组时数组长度必须为常量(或const). 只有初始化时可以用“=”,其它时候均不可以给数组直接赋值,除了赋值的元素以外 ...

  3. Spring MVC 前后端 Json 方式交互和处理

    众所周知,在mvc中,数据是在各个层次之间进行流转是一个不争的事实. 而这种流转,也就会面临一些困境,这些困境,是由于数据在不同世界中的表现形式不同而造成的.   数据在页面上是一个扁平的,不带数据类 ...

  4. 高性能JavaScript 达夫设备

    前言 在<高性能JavaScript>一书的第四章算法和流程控制中,提到了减少迭代次数加速程序的策略—达夫设备(Duff's device).达夫设备本身很好理解,但是其效果是否真的像书中 ...

  5. JAVA GC 简单总结

    GC分代 GC的英文全拼是Garbage Collection,意思是垃圾收集. Java 将堆内存分为三代来管理: - 年轻代 (Young Generation) - 年老代 (Old Gener ...

  6. php缓存技术(减少数据库服务器压力)

    静态缓存(保存在磁盘上的静态文件,用PHP生成数据放入静态文件中) a)  php操作缓存 i.  生成缓存 ii.  获取缓存 iii. 删除缓存 判断目录是否存在:is_dir() dirname ...

  7. linux svn搭建

    1 安装: yum install subversion 2 查看svn安装信息: rpm -ql subversion 3 创建svn根目录: svnserve -d -r /svn 4 进入/sv ...

  8. mybatis缓存学习笔记

    mybatis有两级缓存机制,一级缓存默认开启,可以在手动关闭:二级缓存默认关闭,可以手动开启.一级缓存为线程内缓存,二级缓存为线程间缓存. 一提缓存,必是查询.缓存的作用就是查询快.写操作只能使得缓 ...

  9. XML-RPC远程方法调用

    一.简介 XML-RPC的全称是XML Remote Procedure Call,即XML远程方法调用. 它是一套允许运行在不同操作系统.不同环境的程序实现基于Internet过程调用的规范和一系列 ...

  10. MVC视图引擎优化

    请首先看如下内容: 未找到视图"Index"或其母版视图,或没有视图引擎支持搜索的位置.搜索了以下位置: ~/Views/Home/Index.aspx~/Views/Home/I ...