Ajax笔记 XHR XMLHttpRequest
XMLHttpRequest
xhr XmlHttpRequest
var request ;
if(Windows.XMLHttpRequest)
{ request = new XMLHttpRequest();//IE7 +,Firefox,Chrome,Opera,Safari
}else{
request=new ActiveXObject("Microsoft.XMLHTTP");//IE6,IE5
}
HTTP
网络通信规则
无状态协议 不建立持久的连接
请求过程
1、建立TCP连接
2、浏览器向服务器发送请求命令
3、浏览器发送请求头
4、服务器应答
5、服务器发送相应命令
6、服务器向浏览器发送数据
7、服务器关闭TCP连接
四部分组成:
1、方法、动作 Get orPOST
2、Url 请求地址
3、Header 请求头 客户端环境信息、身份验证
4、请求体 请求正文 客户提交的查询字段 或表单数据
HTTP响应
1、数字和文字组成的状态码
2、响应头 服务器信息 内容长度
3、相应体 相应正文
响应状态码:
1XX: 信息类,表示收到浏览器请求,正在进一步处理中
2XX: 成功,表示用户请求被正确接收
3XX: 重定向,表示请求没有成功,客户必须采取进一步的动作
4XX: 客户端错误,表示客户端提交的请求有错误 例:404 请求文档不存在
5XX: 服务器错误,服务器不能完成对请求的处理
XMLHttpRequest发送请求
open(method,url,async);
open(GET,Http://baidu.com,True);
send(string);
send(name=lala&age=3);
例如:GET
var request = new XMLHttpRequest();
request.open("GET","Http://baidu.com",true);
request.send();
POST
var request = new XMLHttpRequest();
request.open("POST","http://baidu.com",true);
request.setRequestHeader("Content-Type","x-www-form-urlencoded");
request.send("kw=百度一下");
XMLHttpRequest取得响应
resposeText: 获取字符串格式的相应数据
resposeXMl: 获得XML格式的相应数据
status和statusText 以数字和文本形式返回HTTP状态码
getAllResposeHeader(); 获取所有的响应报头
getResposeHeader(); 查询相应中的某个字段的值
readyState属性
0:未初始化 open未调用
1:open调用 服务器已建立
2:服务器已接收 接收到头信息了
3:请求处理中 接收到相应主体了
4:请求已完成 响应完成
request.readState;
request.onreadyStatechange=function(){
if(request.readyState==4 && request.status ==200){
do something;
}
};
Content-Type:
text/plain 纯文本
application/json Json
text/xml XML
text/html HTML
appliaction/javascript Javascript
Json解析
var jsondata = '{"s":[{"name":"a"},{"name":"a"},{"name":"a"}]}
var json = eval('('+jsondata+')');//不判断是否合法 不能屏蔽javascript语句
var json = JSON.parse(jsondata);//校验字符串 屏蔽javascript
JQuery实现Ajax
$.ajax(
type:"POST|GET",
url:"http://baidu.com",
data:{id:id},
dataType:"json",//预期返回的数据类型
success:function(data){},请求成功回掉函数,传入返回后的数据
error:function(data){}//请求失败调用,传入xhr对象
)
跨域
处理跨域方法一 代理
处理跨域方法二 JSONP
处理跨域方法三 XHR2
XMLHttpRequest Level2
IE10以下都不支持
服务器添加响应头:
header('Access-Control-Allow-Origin:"*"');//* 所有域名
header("Acctss-Control-Allow-Methods:POST,GET");
Ajax笔记 XHR XMLHttpRequest的更多相关文章
- Jquery笔记和ajax笔记
Jquery笔记:jQuery是一个JavaScript函数库,专为事件处理设计 1.jQuery的引入 <script text="type/javascript" src ...
- JavaScript:学习笔记(10)——XMLHttpRequest对象
JavaScript:学习笔记(10)——XMLHttpRequest对象 XHR对象 使用XMLHttpRequest (XHR)对象可以与服务器交互.您可以从URL获取数据,而无需让整个的页面刷新 ...
- JavaScript封装Ajax工具函数及jQuery中的ajax,xhr在IE的兼容
封装ajax工具函数 首先要思考:1.为什么要封装它?提高开发效率2.把一些不确定的情况考虑在其中 a. 请求方式 b. 请求地址 c. 是否异步 d. 发送参数 e. 成功处理 f. 失败处理3.确 ...
- $.ajax通用格式&&XMLHttpRequest对象属性和方法
$.ajax({ url: "", type: "POST", async: false, cache:false, //默认true data: {}, da ...
- Ajax技术---核心XMLHttpRequest对象
Ajax 的全称是Asynchronous JavaScript and XML,其中,Asynchronous 是异步的意思,它有别于传统web开发中采用的同步的方式. (一)ajax技术的意义 我 ...
- 学习笔记 之--AJAX核心对象 XMLHttpRequest
实现AJAX功能,核心就是XMLHttpRequest,而且现在大多数浏览器都支持这个核心组件对象. 实例:实现无刷新登陆验证 1.前台代码 <html xmlns="http://w ...
- script ajax / XHR / XMLHttpRequest
s 利用XHR 调试发送form data表单数据,F5键刷新form表单URL ,http请求地址,获取token,提交. 如:http://pcp.cns*****.com/spcp-web/vm ...
- 弄一个ajax笔记方便查询-$.ajax()
$.ajax()是所有ajax方法中最底层的方法,所有其他方法都是基于$.ajax()方法的封装.这个方法只有一个参数,传递一个各个功能键值对的对象. $.ajax()方法对象参数表: 参数 类型 说 ...
- 弄一个ajax笔记方便查询-基础知识篇
jQuery对Ajax做了大量的封装,jQuery采用了三层封装: 最底层的封装方法为:$.ajax() 通过最底层进一步封装了第二层的三种方法:.load().$.get().$.post() 最高 ...
随机推荐
- 201521123010 《Java程序设计》第3周学习总结
1. 本周学习总结 2. 书面作业 1.代码阅读 public class Test1 { private int i = 1;//这行不能修改 private static int j = 2; p ...
- 201521123037 《Java程序设计》第2周学习总结
1. 本周学习总结 初步学会分析使用命令提示符进行编译的命令 了解使用import引入不同包的类 学会码云与eclipse的连接 使用Array和String函数编写程序 2. 书面作业 1. 使用E ...
- 201521123010 《Java程序设计》第2周学习总结
1. 本周学习总结 这周学习了在JAVA里各种数据类型的使用.各种运算符的使用.表达是的使用,还初步学习了枚举的用法,也掌握了一些枚举和switch语句结合的用法,还了解了一些字符串类.在实验课上也学 ...
- 关闭Sublime Text的自动更新的方法
每次打开Sublime text 软件都会提示我让我更新软件,如图: 经过仔细的研究发现可以通过以下途径关闭软件的自动更新 打开Submine Text,找到Preferences -> Set ...
- kettle的HTTPPOST控件发送WSDL的webservice请求配置
1.webservice请求的URL:http://pubservice.rjhn.com.cn/AppserviceTest/JsonWcfService.svc?WSDL 2.使用SOAPUI测试 ...
- 详细解读-this-关键字在全局、函数、对象、jQuery中的基础用法!
一.前言 1. Javascript是一门基于对象的动态语言,也就是说,所有东西都是对象,一个很典型的例子就是函数也被视为普通的对象.Javascript可以通过一定的设计模式来实现面向对象的编程,其 ...
- 新版本mac 无法打开第三方应用
新版本mac 没有任何应用可以打开的这个选项 现在解决方法已经找到 特此标记一下 1打开终端 2 输入 sudo spctl --master-disable 3.打开系统设置的中的安全即可出现
- 实例讲解webpack的基本使用第二篇
这一篇来讲解一下如何设置webpack的配置文件webpack.config.js 我们新建一个webpack-demo的项目文件夹,然后安装webpack 执行如下命令 在项目文件夹下,建一个dis ...
- 【JVM】Java中的JavaCore/HeapDump文件及其分析方法
产生时间 Java程序运行时,有时会产生JavaCore及HeapDump文件,它一般发生于Java程序遇到致命问题的情况下. 有时致命问题发生后,Java应用不会死掉,还能继续运行: 但有时致命问题 ...
- 洗礼灵魂,修炼python(3)--从一个简单的print代码揭露编码问题,运行原理和语法习惯
前期工作已经准备好后,可以打开IDE编辑器了,你可以选择python自带的IDLE,也可以选择第三方的,这里我使用pycharm--一个专门为python而生的IDE 按照惯例,第一个python代码 ...