JavaScript封装Ajax工具函数及jQuery中的ajax,xhr在IE的兼容
封装ajax工具函数
首先要思考:
1、为什么要封装它?提高开发效率
2、把一些不确定的情况考虑在其中
a. 请求方式
b. 请求地址
c. 是否异步
d. 发送参数
e. 成功处理
f. 失败处理
3、确定参数
a. Type--请求方式 get (get/post)
b. Url--请求地址 默认当前地址 字符串
c. Async--是否异步 true (true/false)
d. Data--发送的数据 {} 对象{name:xx}
e. Success--成功回调 function 函数 函数里面就是处理的成功业务
f. Error--失败回调 function 函数 函数里面就是处理失败的业务
/*===============ajax 封装 ===========*/
/*1.确定一个全局对象*/
window.$ = {};
/*2.给全局对象定义一个属性*/
$.ajax = function(options){
/*3.options对象传参 */
/*如果用户不传或者传的不是对象停止执行*/
if(!options || typeof options != 'object') return false;
/*4.默认参数的处理*/
var type = options.type == 'post' ? 'post' : 'get';
var url = options.url || location.pathname;
var async = options.async === false ? false : true;
var data = options.data || {};
/* 对象形式的数据 需要转换成键值对的数据字符串 XHR对象需要 */
var data2str = '';
for(var key in data){
data2str += key+'='+data[key]+'&';
}
/*需要去掉最后一个&*/
data2str = data2str && data2str.slice(0,-1);
/*if(data2str){
data2str = data2str.slice(0,-1);
}*/
/*请求发送之前*/
if(options.beforeSend){
var flag = options.beforeSend();
if(flag === false){
return false;
}
}
/*5.ajax 编程*/
/*5.1 初始化对象*/
var xhr = new XMLHttpRequest();
/*5.2 设置请求行*/
xhr.open(type,type == 'get' ? (url+'?'+data2str) : url,async);
/*5.3 设置请求头*/
if(type == 'post'){
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
}
/*5.4 设置请求主体 发送*/
xhr.send(type == 'get'?null:data2str);
xhr.onreadystatechange = function(){
/*5.5 通讯完成*/
if(xhr.readyState == 4){
/*5.6 成功的*/
if(xhr.status == 200){
/*需要考虑问题 数据格式问题*/
/*1.怎么确定后台返回的数据格式?*/
/*2.后台有写接口的时候 规范 xml application/xml json application/json*/
var result = null;
var contentType = xhr.getResponseHeader('Content-Type');
/*3.如果有xml 就是xml格式数据*/
if(contentType.indexOf('xml') > -1){
result = xhr.responseXML;
}
/*4.如果有json 就是json格式数据*/
else if(contentType.indexOf('json') > -1){
result = JSON.parse(xhr.responseText);
}
/*5.如果有标识 普通文本*/
else{
result = xhr.responseText;
}
/*调用成功回调函数 把数据传递过去*/
options.success && options.success(result);
}
/*5.7 失败的*/
else{
/*调用失败回调函数*/
options.error && options.error({status:xhr.status,statusText:xhr.statusText});
}
}
};
/*
$.ajax({error:function(msg){}});
$.ajax({success:function(data){}});
* */
};
/*get*/
$.get = function(options){
options.type = 'get';
$.ajax(options);
};
/*post*/
$.post = function(options){
options.type = 'post';
$.ajax(options);
};
jQuery Ajax 操作函数
jQuery 库拥有完整的 Ajax 兼容套件。其中的函数和方法允许我们在不刷新浏览器的情况下从服务器加载数据。
| 函数 | 描述 |
|---|---|
| jQuery.ajax() | 执行异步 HTTP (Ajax) 请求。 |
| .ajaxComplete() | 当 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。 |
| .ajaxError() | 当 Ajax 请求完成且出现错误时注册要调用的处理程序。这是一个 Ajax 事件。 |
| .ajaxSend() | 在 Ajax 请求发送之前显示一条消息。 |
| jQuery.ajaxSetup() | 设置将来的 Ajax 请求的默认值。 |
| .ajaxStart() | 当首个 Ajax 请求完成开始时注册要调用的处理程序。这是一个 Ajax 事件。 |
| .ajaxStop() | 当所有 Ajax 请求完成时注册要调用的处理程序。这是一个 Ajax 事件。 |
| .ajaxSuccess() | 当 Ajax 请求成功完成时显示一条消息。 |
| jQuery.get() | 使用 HTTP GET 请求从服务器加载数据。 |
| jQuery.getJSON() | 使用 HTTP GET 请求从服务器加载 JSON 编码数据。 |
| jQuery.getScript() | 使用 HTTP GET 请求从服务器加载 JavaScript 文件,然后执行该文件。 |
| .load() | 从服务器加载数据,然后把返回到 HTML 放入匹配元素。 |
| jQuery.param() | 创建数组或对象的序列化表示,适合在 URL 查询字符串或 Ajax 请求中使用。 |
| jQuery.post() | 使用 HTTP POST 请求从服务器加载数据。 |
| .serialize() | 将表单内容序列化为字符串。 |
| .serializeArray() | 序列化表单元素,返回 JSON 数据结构数据。 |
- jQuery为我们提供了更强大的Ajax封装
- $.ajax({}) 可配置方式发起Ajax请求
- $.get() 以GET方式发起Ajax请求
- $.post() 以POST方式发起Ajax请求
- $('form').serialize() 序列化表单(即格式化key=val&key=val)
- url 接口地址
- type 请求方式
- timeout 请求超时
- dataType 服务器返回格式
- data 发送请求数据
- beforeSend: function () {} 请求发起前调用
- success 成功响应后调用
- error 错误响应时调用
- complete 响应完成时调用(包括成功和失败)
$(function(){
$.ajax({
/*1.请求方式*/
type:'get',
/*2.接口地址*/
url:'01 jquer1yAjax.php',
/*3.传递数据*/
data:{
username:'xqq'
},
/*4.限制返回数据类型 强制转换数据类型 如果转换不成功 会执行错误的回调函数*/
dataType:'json',
/*5.请求之前的回调函数*/
beforeSend:function(){
console.log('beforeSend');
/*如果请求回调函数 返回的是 false 停止ajax发送*/
//return false;
},
/*6.成功回调函数*/
success:function(data){
console.log(data);
},
/*7.失败回调函数*/
error:function(){
console.log('error');
},
/*8.通讯完成回调函数*/
complete:function(){
console.log('complete');
}
});
}); - XHR的IE兼容性
function XHR() {
/*XMLHttpRequest 存在兼容问题*/
/*1.申明一个xhr*/
var xhr;
/*2.运行出现错误 异常 */
/*3.捕获异常*/
try {
/*在不支持这个对象的时候 出现异常*/
xhr = new XMLHttpRequest();
}
/*4.处理异常*/
catch(e) {
/*低版本IE浏览器 初始化xhr对象需要的不同参数*/
var IEXHRVers =["Msxml3.XMLHTTP","Msxml2.XMLHTTP","Microsoft.XMLHTTP"];
/*变量数组*/
for (var i=0;i<IEXHRVers.length;i++) {
/*5.捕获异常*/
try {
/*低版本IE初始化xhr对象的方式*/
xhr = new ActiveXObject(IEXHRVers[i]);
}
catch(e) {
continue;
}
}
}
return xhr;
}
JavaScript封装Ajax工具函数及jQuery中的ajax,xhr在IE的兼容的更多相关文章
- 深入理解ajax系列第九篇——jQuery中的ajax
前面的话 jQuery提供了一些日常开发中需要的快捷操作,例如load.ajax.get和post等,使用jQuery开发ajax将变得极其简单.这样开发人员就可以将程序开发集中在业务和用户体验上,而 ...
- $.ajax()方法详解 jquery中的ajax方法
jquery中的ajax方法参数总是记不住,这里记录一下. 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为String类型的参数,请求方式(p ...
- 从零开始学 Web 之 Ajax(六)jQuery中的Ajax
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- Javascript 常用的工具函数,更新中...
1.时间戳转为格式化时间 /** * 时间戳转为格式化时间 * @Author chenjun * @DateTime 2017-11-10 * @param {[date]} timestamp [ ...
- 封装一个Ajax工具函数
/*封装一个ajax工具函数*/ window.$ = {}; /*通过$定义一个ajax函数*/ /* * 1. type string 请求的方式 默认是get * 2. url ...
- jquery中的ajax方法
$.ajax()方法详解 jquery中的ajax方法参数总是记不住,这里记录一下. 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为Strin ...
- JavaScript原生封装ajax请求和Jquery中的ajax请求
前言:ajax的神奇之处在于JavaScript 可在不重载页面的情况与 Web 服务器交换数据,即在不需要刷新页面的情况下,就可以产生局部刷新的效果.Ajax 在浏览器与 Web 服务器之间使用异步 ...
- JQUERY中各个ajax函数
1.$(selecter).load() --- load() 方法从服务器加载数据,并把返回的数据放入被选元素中 2.$.get(url,callback()) 3.$.post(url,d ...
- AJAX编程-封装ajax工具函数
即 Asynchronous [e'sɪŋkrənəs] Javascript And XML,AJAX 不是一门的新的语言,而是对现有技术的综合利用.本质是在HTTP协议的基础上以异步的方式与服务器 ...
随机推荐
- 011-Shell 文件包含
和其他语言一样,Shell 也可以包含外部脚本.这样可以很方便的封装一些公用的代码作为一个独立的文件. Shell 文件包含的语法格式如下: . filename # 注意点号(.)和文件名中间有一空 ...
- Spark2.0机器学习系列之11: 聚类(幂迭代聚类, power iteration clustering, PIC)
在Spark2.0版本中(不是基于RDD API的MLlib),共有四种聚类方法: (1)K-means (2)Latent Dirichlet all ...
- webuploader 多图片上传
WebUploader是由Baidu WebFE(FEX)团队开发的一个简单的以HTML5为主,FLASH为辅的现代文件上传组件. 具体接口参考 webuploader接口文档地址 一.图片上传功能 ...
- #pragma 的用法
它的作用是设定编译器的状态或者是指示编译器完成一些特定的动作.#pragma指令对每个编译器给出了一个方法,在保持与C和C++语言完全兼容的情况下,给出主机或操作系统专有的特征.依据定义,编译指示是机 ...
- 过滤adb logcat 日志
原文地址http://blog.csdn.net/listening_music/article/details/7518990 另外比较好的文章http://blog.csdn.net/liao27 ...
- phpcms发布到服务器修改
请进行以下步骤的修改: 1.修改/caches/configs/system.php里面所有和域名有关的,把以前的老域名修改为新域名就可以了. 2.进行后台设置->站点管理 对相应的站点的域名进 ...
- 2016-2017 National Taiwan University World Final Team Selection Contest J - Zero Game
题目: You are given one string S consisting of only '0' and '1'. You are bored, so you start to play w ...
- Winter-2-STL-A Argus 解题报告及测试数据
Time Limit:2000MS Memory Limit:65536KB Description A data stream is a real-time, continuous, ord ...
- 通过Java编码获取String分行字符串的内容
代码案列: import java.io.BufferedReader; import java.io.ByteArrayInputStream; import java.io.IOException ...
- 好用的http client库CPP REST SDK
前言 C++中http client库本身就少,好用的就更少了,在了解微软开源的CPP REST SDK库之前,我知道的C++ http client库有libcurl(这个是C语言的),Qt的QNe ...