AJAX--总结
2018-9-6 14:42:53 ? AJAX简介? HTTP协议------>HTTP权威指南 ? 请求:客户端去向服务端请求一个文件 ? 响应:服务端把对应的文件内容返回给客户端,一般服务端有输出才算真正的响应. ? 传统请求:地址栏刷新请求 ? AJAX:通过技术偷偷请求 创建对象? new XMLHttpRequest(); 属性readyStateHTTP 请求的状态.当一个 XMLHttpRequest 初次创建时,这个属性的值从 0 开始,直到接收到完整的 HTTP 响应,这个值增加到 4。
readyState 的值不会递减,除非当一个请求在处理过程中的时候调用了 abort() 或 open() 方法。每次这个属性的值增加的时候,都会触发 onreadystatechange 事件句柄。 responseText服务器接收到的响应体(不包括头部),如果还没有接收到数据的话,就是空字符串。 status由服务器返回的 HTTP 状态代码,如 200 表示成功。 ? 事件句柄onreadystatechange每次 readyState 属性改变的时候调用的事件句柄函数。当 readyState 为 3 时,它也可能调用多次。 方法open()初始化 HTTP 请求参数,例如 URL 和 HTTP 方法,但是不发送请求。 open(method,url,async,username,password)
method 参数是用于请求的 HTTP 方法。值包括 GET、POST 和 HEAD。 url 参数是请求地址。 async 参数指示请求使用应该异步地执行。如果这个参数是 false,请求是同步的,后续对 send() 的调用将阻塞,直到响应完全接收。如果这个参数是 true(默认),请求是异步的,且通常需要一个 onreadystatechange 事件句柄。username 和 password 参数是可选的,为 url 所需的授权提供认证资格。如果指定了,它们会覆盖 url 自己指定的任何资格。 send()发送 HTTP 请求,get方法无参,post方式有可选参。 setRequestHeader()向一个打开但未发送的请求设置或添加一个 HTTP 请求。 ? AJAX+PHP流程
GET传参可以直接拼接传参 POST传参setRequestHeader() 设置Post传参 方法原理: ? 模拟表单 HTML表单enctype值介绍
放在send之前,open之后 setRequestHeader(‘‘,‘application/x-www-form-urlencoded‘) send(‘a‘+n1+‘a2‘+n2) 数组处理php后端:? encho json_encode() ---------->将PHP数据转为JSON 前端:? eval() 计算 JavaScript 字符串,并把它作为脚本代码来执行。 ? 1.eval(‘var yy = ‘ + jsonstr ) ? 2.var yy = eval(‘({json字符串})‘) ? JSON解析器只解析json ? JSON.parse() 同步异步? open()方法的参3,用于控制是否同/异步 默认参数为true,表示请求是异步的,AJAX不会影响到其他程序的执行. 参数为false,表示请求是同步的. AJAX将阻塞之后的程序运行,直到响应完全接收完毕为止. AJAX无法跨域与jsonp? AJAX无法跨域 JSONP利用到script标签 不受同源策略的影响.所以可以跨域 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |