js原生Ajax(十四)
一、XMLHttpRequest 【使用XMLHttpRequest时,必须将html部署到web服务器中】
1) 指定请求
1、实例化
eg:
var http = new XMLHttpRequest();
http为实例化的XMLHttpRequest对象,该对象可以重用,但是这将会终止之前通过该对象挂起的任何请求。
2、指定请求
open(method,url,async)
参数:
method:请求的类型;GET 或 POST 等
url:文件在服务器上的路径
async:true(异步)或 false(同步)【默认值为true】
eg:
http.open("GET","data.xml");
3、设定请求头【请求体是否传递数据来调用】
setRequestHeader(key,value);
如果有请求头,需要调用该方法进行设定。
参数:
1.key: 传递数据类型属性
2.value: 对应的属性值
eg:
//将Content-Type设置为表单格式
http.setRequestHeader("Content-type","application/x-www-form-urlencoded;charset=UTF-8");
注意:
XMLHttpRequest将自动添加以下这些请求头以防止伪造,我们无法向setRequestHeader()传递以下请求头。
Accept-Charset TE Content-Transfer-Encoding
Accept-Encoding Date Trailer
Connection Expect Transfer-Encoding
Content-Length Host Upgrade
Cookie Keep-Alive User-Agent
Cookie2 Referer Via
4. 指定可选的请求主体并向服务器发送
send(param)
参数:
param: 请求主体内容,如果没有,为null或者省略。
eg:
/*
使用POST方法发送纯文本给服务器
*/
function postMessage(url,msg){
var request = new XMLHttpRequest();
request.open("POST",url);
request.setRequestHeader("Content-type","text/plain;charset=UTF-8");
request.send(msg);
}
2) 取得响应
1、HTTP状态码:
a、status 【以数字形式返回HTTP状态码】
200 OK
404 Not Found
403 forbidden JSONP【解决跨域请求,一般后台处理该问题】
500 后台代码异常
b、statusText 【以文本形式返回HTTP状态码】
OK
Not Found
2、获取响应的一些相关信息
getResponseHeader() 获取指定响应头
getAllResponseHeaders() 获取所有响应头
responseText 获取文本形式的响应体
responseXML 获取Document形式的响应体
readyState 返回HTTP请求状态【每当 readyState 改变时,就会触发 onreadystatechange 事件】
readyState相关状态值:
0 open()尚未调用 UNSENT
1 open()已调用 OPENED
2 接收到头信息 HEADERS_RECEIVED
3 接收到响应主体 LOADING
4 响应完成 DONE【响应完成,可以获取响应体】
3、readystatechange 请求状态改变事件【使用时前面需添加on eg:onreadystatechnage】
当readyState值改变为4或服务器的响应完成时,所有的浏览器都触发该事件
eg:
/*
获取HTTP响应
*/
function getText(url,callback){
var http = new XMLHttpRequest();
http.open("GET",url);
request.onreadystatechange = function(){
//如果请求完成,并且请求成功
if(http.readyState === 4 && http.status ===200){
var type = http.getResponseHeader("Content-type");
if(type.match(/^text/)){ //如果响应是文本
callback(http.responseText);//执行回调函数
}
}
};
http.send(null);
}
3) 响应解码
1.MIME类型为text/plain,text/html,text/css 文本类型时,可以使用responseText属性解析
2.MIME类型为XML文档类型时,使用responseXML属性解析
3.如果服务器发送对象,数组这样的结构化数据作为其响应,他应该传输JSON编码的字符串数据。
通过responseText接受到它,可以把它传递给JSON.parse()方法来解析成js对象。
二、使用自己的方法封装原生ajax
eg:
function myAjax(method,url,param,success,fail){
//后台服务器地址及端口号
var baseUrl = 'http://134.175.154.93:8099';
//前端传递给后台的参数
//handle当内部的异步执行成功的回调函数,需要将后台返回的数据交给handle
//1、创建XMLHttpRequest 对象
var http = new XMLHttpRequest();
//处理GET方式携带参数
if(method === 'GET' && param){
url += '?'+encodeFormData(param);
}else{ }
//2、向服务器发送请求
http.open(method,baseUrl+url);
//3、HTTp状态值readystate改变时的响应事件
http.onreadystatechange = function(){
//如果HTTP返回状态码为200(请求成功)且返回HTTP状态值为4(响应完成)时执行成功回调函数success()
if (http.status === 200 && http.readyState === 4) {
console.log('请求成功!!!');
success(JSON.parse(http.responseText)); //将返回的JSON字符串解析成js对象并作为回调函数的参数
}
//如果返回HTTP状态码不为200(不是请求成功)执行失败回调函数fail()
if(http.status !== 200){
fail(http.responseText);
}
};
//处理POST方式携带参数
if (method === 'POST' && param) {
//设置请求头其Content-Type类型为表单格式
http.setRequestHeader('Content-Type','application/x-www-form-urlencoded;charset=UTF-8');
//4、将请求发送给服务器并携带数据信息
http.send(encodeFormData(param));
}else{
//4、将请求发送给服务器不携带数据信息
http.send();
} } //将js的对象转换成表单格式数据
function encodeFormData(data){
if(!data){
return "";
}
var pairs = [];
for(var name in data){
if(!data.hasOwnProperty(name)){
continue;
}
if(typeof data[name] == "function"){
continue;
}
var value = data[name].toString();
name = encodeURIComponent(name.replace("%20","+"));//编码名字
value = encodeURIComponent(value.replace("%20","+"));//编码值
pairs.push(name+"="+value);
}
return pairs.join('&');
}
js原生Ajax(十四)的更多相关文章
- JS原生ajax
原文链接:http://caibaojian.com/ajax-jsonp.html 一.JS原生ajax ajax:一种请求数据的方式,不需要刷新整个页面: ajax的技术核心是 XMLHttpRe ...
- JS原生Ajax&Jquery的Ajax技术&Json
1.介绍Ajax Ajax = 异步 JavaScript 和 XML Ajax是一种创建快速动态网页的技术 通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新.这意味着可以不用整个 ...
- JS原生ajax与Jquery插件ajax深入学习
序言: 近来随着项目的上线实施,稍微有点空闲,闲暇之时偶然发现之前写的关于javascript原生xmlHttpRequest ajax方法以及后来jquery插件ajax方法,于是就行了一些总结,因 ...
- js原生Ajax的封装与使用
一.原生Ajax代码的封装如下: (function() { var XHR = { createStandardXHR: function() { return new XMLHttpRequest ...
- js原生Ajax 的封装和原理
原理及概念 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是一种用于创建快速动态网页的技术. 动态网页:是指可以通过服务器语言结合数 ...
- Jquery学习笔记 --ajax删除用户,使用了js原生ajax
主要复习了php的pdo数据库操作,和js的ajax,真麻烦,希望jquery的ajax简单点. index.php: 1 <!DOCTYPE html> 2 <html lang= ...
- [代码]JS原生Ajax,GET和POST
javascript/js的ajax的GET请求: <script type="text/javascript"> /* 创建 XMLHttpRequest 对象 */ ...
- Jquery学习笔记(10)--ajax删除用户,使用了js原生ajax
主要复习了php的pdo数据库操作,和js的ajax,真麻烦,希望jquery的ajax简单点. index.php: <!DOCTYPE html> <html lang=&quo ...
- js 原生 ajax
//js ajax function Ajax(url,type,data,comFun,sucFun,errFun) { //1.创建XMLHttpRequest对象 var xmlHttpRequ ...
随机推荐
- 微信2.1 for Windows发布 微信群可多人语音或视频通话
5月31日,windows电脑版微信发布更新,微信2.1 for Windows带来最主要的功能是微信群可以多人语音或视频通话了,建个家庭群组,常年在外工作的家人也可以每天见面了,多亲切! 除了可以建 ...
- SaaS加速器 III 技术中心:提供SaaS Launchkit,快速定制,一云多端等能力,一云多端将通过小程序云实现
https://yq.aliyun.com/articles/695746 演讲主题:SaaS加速器 III技术中心:聚合开放 高效强大 技术中心定义:阿里云以聚合开放的姿势,提供一个高效强大的技术开 ...
- mdk编译器学习笔记(1)——序
这两天,学习了keil-mdk编译器的特性,这基本上独立于c语言语法,平时基本上都在强调c语言的学习,但是编译器的学习我们也要注重,类似于gcc一样,不也有很多网上的资料,讲述gcc的特性和用法吗.作 ...
- IConvertible接口
IConvertible接口:定义特定的方法,这些方法将实现引用或值类型的值转换为具有等效值的公共语言运行库类型. 公共语言运行库类型包括: Boolean.SByte.Byte.Int16.UInt ...
- 学习:VB之4C法
前言:4C法对于单纯的本地验证的话应该比较好使,但是基于网络验证可能就不是很好用了,尽管到了第二个窗口,功能应该还是不能用 逆向过程: 1.直接载入OD,发现第一条汇编指令如下 0040120C &g ...
- LeetCode 1216. Valid Palindrome III
原题链接在这里:https://leetcode.com/problems/valid-palindrome-iii/ 题目: Given a string s and an integer k, f ...
- VS中的Modules窗口
当我在别人的机器上调试问题时,我做的第一件事就是查看modules窗口.按版本排序并看到一个不属于的dll可以帮助立即诊断配置问题,并节省许多调试痛苦. 下面介绍下各列的意思: Name:模块名称. ...
- CF598: div3解题报告
CF598:div3解题报告 A: Payment Without Change 思路: 按题意模拟即可. 代码: #include<bits/stdc++.h> using namesp ...
- ABP 从core降到级.net framework
后台: Application层得先写接口 再写实现,不然 abp.services.app 这个里面就没有该service.并且service保留的接口,就是interface里面定义的接口. 文件 ...
- gnome3 调整标题栏高度
适用于:gtk 3.20 + 1. 在用户主目录 -/.config/gtk3.0/ 下新建gtk.css文件: 2. 复制如下css值: headerbar.default-decoration { ...