Ajax 同步、异步
一、XMLHttpRequest (XHR)对象
data:image/s3,"s3://crabby-images/e2431/e24311456a2724920b21ab4dd4a11870cbe0b4ff" alt=""
发送请求:
open(method,url,async)
send(string)
data:image/s3,"s3://crabby-images/22c6a/22c6acdcb4cf29ee1ae669c4c983f27931b3a47e" alt=""
获取响应:
responseText:获取字符串形式的响应数据
responseXML:获取XML形式的响应数据
status和statusText : 以数字和文本形式返回HTTP状态码
getAllResponseHeader() :获取所有的响应报头
getResponseHeader() :查询响应中的某个字段的值
readyState属性:
0:请求未初始化 open还没调用
1:服务连接已建立 open已经调用
2:请求已接收 (接收到头信息了)
3:请求处理中 (已经接收到响应主题)
4:请求已完成 且响应已就绪
data:image/s3,"s3://crabby-images/18ba5/18ba5d089bcc54b198215def61a2e82508626f80" alt=""
二、HTTP 请求
HTTP是一种无状态协议
HTTP是计算机通过网络进行通信的规则
data:image/s3,"s3://crabby-images/1dd6b/1dd6b76f1618bb0ab51632c01fc17cc74eb6fece" alt=""
解析:1. HTTP请求方法或动作 比如GET/POST请求
2. 正在请求的URL
3. 请求头,包含一些客户环境信息 身份验证信息等
4. 请求体 也就是请求正文 请求正文中可以包含客户提交的查询字符串信息 表单信息等
data:image/s3,"s3://crabby-images/4f5f6/4f5f6cb0bbe7d9fc6b1a84005a2983180e80de67" alt=""
data:image/s3,"s3://crabby-images/811ac/811acb211923e9eddf0d69db29c7cf7113df8e4d" alt=""
data:image/s3,"s3://crabby-images/86a21/86a2148818dcfa99b0f5defc6830ef3594ad87bb" alt=""
data:image/s3,"s3://crabby-images/afa7a/afa7aac2bb1b43fdbdfaaa7d5f368a65d033ca0d" alt=""
三、JSON
data:image/s3,"s3://crabby-images/55182/551820c478814d2a30cdcdaed3a7c4b5a0dc0102" alt=""
json 与 xml比较:
data:image/s3,"s3://crabby-images/e6237/e623779935d0216f0b4956a899a6a2596052ca00" alt=""
json语法规则:
data:image/s3,"s3://crabby-images/e714c/e714c8db5ba267f1c149f8c5c4dc91d89e0fce7c" alt=""
data:image/s3,"s3://crabby-images/3cfea/3cfea28b09195111fe18c3fb561b7104daf57e1b" alt=""
json 解析:
eval 和 JSON.parse
data:image/s3,"s3://crabby-images/ed659/ed659cb884ad4254c3ce5721d762990e8151f588" alt=""
data:image/s3,"s3://crabby-images/98d5f/98d5f758a04f2c58ebd742f26afde6e9f0da4fb1" alt=""
eval 比较危险
JSON.parse 会检验json格式 返回错误
json格式化:
data:image/s3,"s3://crabby-images/3efdf/3efdfba5663c38b7f48e50a6f0eab93cf54461da" alt=""
jQuery中 Ajax
1. jQuery.ajax([settings])
data:image/s3,"s3://crabby-images/80263/80263f3821269b182808950fd39b5b57b28a2eb3" alt=""
data:image/s3,"s3://crabby-images/fb863/fb86348dcf026a9a8c4ac169418a49c9cf228d00" alt=""
跨域
data:image/s3,"s3://crabby-images/817ea/817ea6715fd65af30d0ce465ade6b50575da2bf0" alt=""
data:image/s3,"s3://crabby-images/e9b27/e9b274fefec472a5376b12ed111e6759f4559a0f" alt=""
data:image/s3,"s3://crabby-images/afbcd/afbcd98c952818f4ae1ca2b3c1997226862bcaf8" alt=""
处理跨域:
1> 代理
2> JSONP
data:image/s3,"s3://crabby-images/f44d6/f44d63bd321a914c6ebe8a95e117a76d80dfae42" alt=""
局限:不支持POST方式 支持GET方式
3>XHR2
data:image/s3,"s3://crabby-images/29b70/29b70479e30763865c13f03175c70b53c9db2c5e" alt=""
网友评论