之前对于ajax没有详细的学习,只是碰到的时候,就记一点,不是很有条理。虽然常用的都会用,但真经不起询问,知其然而不知其所以然,所以专门看了一下《JavaScript高级程序设计》中对ajax的讲解。

  本文基本都摘抄自《JavaScript高级程序设计》

  ajax其实就是使用window对象的XMLHttpRequest对象,这个对象和其他的Date,Array一样,都是window对象自带的,所以声明一个XMLHttpRequest实例对象也和声明Date,Array对象一样。

声明对象

var xhr = new XMLHttpRequest();

  此处没有考虑IE,因为在实际开发过程中,一般不会使用原生的js,都是用jquery,所以不用考虑兼容性,我们只需要知道原理即可。

  

设置请求参数

xhr.open("请求的方法","请求的URL","是否以异步方式请求")

  请求的方法可以使get、post、put、delete等,http协议支持的应该都是可以的,只不过最常用的是get和post,并且这里不区分大小写。

  请求的URL,需要注意的是,不要跨域,即只能请求和当前脚本在同一个域下面的资源,也就是请求的host:port和当前的执行脚本的host:port必须相同。如果想跨域请求的话,就另当别话,后面会提。

  是否以异步方式请求,同步和异步就不说了,推荐使用异步,即这里设为true。如果使用同步的话,浏览器会出现警告,不过会继续运行,可以忽略警告。

设置http头部信息

xhr.setRequestHeader("key","value");

  实际开发中,请求接口可能需要请求方携带者颁发给自己的token或者cert,很多时候就是通过将这些token或者cert添加在header中的。

  发送的header,可以在浏览器的network中,选择对应的请求文件,查看header一栏,找到Request Header。

  

发送请求

xhr.send();

  send方法可以接受参数,当然也可以不传,《js高程》中说即使不需要发送数据,也必须传入null。

  执行完这条语句后,就真的是发起请求了,可以在浏览器控制台查看network。

  需要注意的是:

  send方法传递非null参数的情况只适用于post方法。如果是以get方式请求,此时即使传递给send方法的参数,传递的参数也不会发送。

  如果是以get方式请求,不要将数据写在send方法中,可以在请求的URL后面增加查询参数,就像host:port/index.php?name="abc"。需要注意的是,像老一点的IE,是不会自动编码URL的,所以一定要使用encodeURIComponent(string)编码后再连接到URL中。

  如果是以post方式发送,那么可以在send方法中传递要发送的数据,但是,必须制定header,比如设置Content-Type为x-www-form-urlencoded,然后在将数据写在send方法中,如果不指定header,那么数据也是能发送的,如果后端是PHP,虽然不能使用$_POST来接收send中发送的数据,但是可以使用下面的方法来获取数据:

$post_data = file_get_contents('php://input');

  但是,强烈推荐,设置header,这样后端处理比较方便。

  另外,

  如果不加header,在浏览器中console中可以看到发送数据的格式是Request Payload;

  加上header,比如Content-Type为x-www-form-urlencoded,发送的数据就是Form Data;

  关于Request PayLoad和Form Data的区别,网上很多博客讲解,这里就不抄了。

对返回值进行接收处理 

  可以通过console.log(window)来找到XMLHttpRequest对象,以及XMLHttpRequest对象下面的各种属性和事件方法。

  常用的属性如下:

  responseText -> 作为响应主体被返回的文本;

  responseXML -> 如果后端程序在返回的数据是,设置Content-Type为text/xml或者application/xml,那么就用这个属性接收xml格式的响应内容。

  status  -> http状态码;

  readyState -> 反映出xhr对象请求数据进行哪个阶段,注意并不是调用send之后,他的值才变。

    0  -> 尚未初始化,未调用open方法;

    1  -> 调用了open方法;

    2 -> 调用了send方法;

    3 -> 接收到部分数据;

    4 -> 数据全部接收完成,可以使用了。

而对于处理结果,常用的事件有 readyStateChange,对应的事件处理程序是onreadyStateChange,从名称就能想出来它和readyState的关系吧。

所以通常为该事件处理程序绑定一个函数。做法如下:

var xhr = new window.XMLHttpRequest();
xhr.open("post","recieve.php?id=name",true);
xhr.setRequestHeader("myToken","abcdefghti");
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xhr.send("name=abc&age=10");
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
if((xhr.status==200 && xhr.status<300) || xhr.status==304){
console.log(xhr.responseText);
} else {
console.log("请求失败,响应码:" + xhr.status)
}
}
}

  

超时设定

  xhr对象有一个timeout属性,表示在发起请求后,多少毫秒内还没有收到结果,就会触发timeout事件,对应的是ontimeout事件处理程序。

  注意,一旦超过设定的超时时间,就会canceled(取消请求),即不会再关注响应的结果,已经将此次请求认定为失败了。

var xhr = new XMLHttpRequest();
xhr.open("get","recieve.php",true);
xhr.send();
xhr.timeout = 1000;//1秒超时
xhr.ontimeout = function(){
console.log("Request Timeout")
}
xhr.onreadystatechange = function(){
if(xhr.readyState==4){
if((xhr.status==200 && xhr.status<300) || xhr.status==304){
console.log(xhr.responseText);
} else {
console.log("请求失败,响应码:" + xhr.status)
}
}
}

  

  

Ajax的使用~~~整理的更多相关文章

  1. 初步认识ajax(个人整理)

    通过使用ajax可以实现页面的部分动态化 ajax可以发送一个请求去服务端,而服务端则发送回一小段数据给客户端,这样就可以避免加载整个页面,因为很多时候页面只需要刷新某一部分的数据,而其他大部分体就不 ...

  2. AJAX结合PHP整理复习

    Ajax主要的功能是实现了浏览器端 异步 访问服务器:通过浏览器的XMLHttpRequest对象发出小部分数据,与服务端进行交互,服务端返回小部分数据,然后更新客户端的部分页面. 下图是一次请求成功 ...

  3. Django - Ajax基本内容整理

    将原来的请求结果普通字符串,变更为类字典的字符串 从这段代码中,可以看到,对原有函数,进行了一个try ...except....操作,进行异常捕捉,将捕捉过程及结果,存入在初始化的字典中,将字典通过 ...

  4. 【学】jQuery的源码思路6——增加each,animaion,ajax以及插件机制

    each() 插件机制 animation ajax //each() //这里第一个参数指定将this指向每次循环到的那个元素身上,而第三个参数element其实就是this本身所以和第一个参数是一 ...

  5. javascript常用函数封装——运动、cookie、ajax、获取行内样式兼容写法、拖拽

    运动.cookie.ajax.获取行内样式兼容写法.拖拽封装大合集. //url,data,type,timeout,success,error function ajax(options){ //- ...

  6. Django web 基础

    一.Django概述 Django大而全; 创建Django工程:django-admin startproject sitename 创建django之后生成的目录结构如下: Project Pro ...

  7. 01:django基础篇

    Django其他篇 目录: 1.1 django初探 1.2 第一个django项目 1.3 django render/redirect/HttpResponse 和 request.GET req ...

  8. 复习 | 重温jQuery和Zepto的API

    jq和zepto很相似有许多共同的api,zepto也出了很多与jq不一样的api,总的来说,两者更相似,但是zepto更轻量一点,正好公司也在用,复习这两个没错 jq中的zepto的事件和ajax我 ...

  9. Ajax学习整理

    什么是ajax?W3School中给ajax的定义是: 1.AJAX = 异步 JavaScript 和 XML. 2.AJAX 是一种用于创建快速动态网页的技术. 3.通过在后台与服务器进行少量数据 ...

随机推荐

  1. one_code=soup.find('a',href=re.compile(r"ill")) NameError: name 're' is not defined

    啊啊啊啊我又来了,真的是万事开头难啊,一个问题刚解决,又来了一个问题..依旧跟着视频教学,说“re"这里按Ctrl+e导入正则表达式,可我弄了半天也没有反应..以至于最后的运行结果就是这样. ...

  2. AJAX基础知识点学习

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/huangyibin628/article/details/28281003 1.AJAX(Async ...

  3. centos7下安装docker(12.2自定义网络)

    通常默认的情况下我们使用的是docker的bridge的网络,用户也可以根据自己的业务需要,创建user-defined docker 提供三种user-defined网络驱动:bridge,over ...

  4. QT 13 窗口屏幕设置大小与居中显示

    <pre name="code" class="cpp">#include "mainwindow.h" #include &l ...

  5. Spring配置文件和SpringMVC配置文件 web.xml配置文件 保存自用

    话不多说,最近在周末自己抽时间写一些框架做的系统,当所有东西都需要自己配置时候发现自己压根记不住这么多类和路径,所以日常总结就变得尤为重要了 db-config.properties 将配置文件常量提 ...

  6. pyspider安装完启动报错【connect to scheduler rpc error: error(111, 'Connection refused')】

    调研爬虫框架pyspider有一段时间了,感觉已经比较成熟,跟老板申请了一台机器,打算搭一套正式环境.然而在熟悉的安装步骤过后,启动画面却是这样的: 虽然心中有疑惑,但还是熟练的百度起来.一番搜索之后 ...

  7. 关于栈和队列的一点点小知识-----C++自带函数

    栈和队列我们可以用C++里自带的函数使用,就不必手写了 1.栈,需要开头文件 #include<stack>  定义一个栈s:stack<int> s; 具体操作: s.emp ...

  8. Android Studio中依赖第三库导致support版本冲突解决方案

    1.今天在Android Studio的app/gradle文件中依赖文件选择器的第三方库:“com.leon:lfilepickerlibrary:1.8.0” 时,github地址:https:/ ...

  9. Fragment+FragmentActivity出现The specified child already has a parent. You must call removeView() on the child's parent first.

    这个异常是出现在Fragment中的onCreateView方法中初始化布局时发生的. View view = inflater.inflate(R.layout.fragment3_layout, ...

  10. SkylineGlobe的PopupMessage里面嵌入的网页如何与主页面交互通讯

    1.主页面调用PopupMessage,如果需要传值,就是普通的页面间的传值就可以实现了. a.html页面调用PopupMessage创建方法,url传入b.html?x=111&y=22; ...