ajax(即:Asynchronous JavaScript and XML(异步的 JavaScript 和 XML))经常在用,却经常忽略了底层的实现机制,今日写个小工具,大家也可拿去使用,如果写博客时需要引用时,请显著地注明出处,以尊重劳动成果,谢谢~

  声明:本文仅讲述关于:JavaScript的ajax工具类设计ajax规范设计者开放了哪些接口、以及ajax使用Demo

零、推荐文献

  [1] 轻量级AJAX库-搜狗实验室ajax.js

  [2] 跨域问题小结

一、Chrome控制台网络调试小工具[方便、快捷、易用]

var xml = new XMLHttpRequest();
xml.withCredentials = true; // 开启Cookie,启用会话机制
var url = "http://10.66.1.1/abc.jsp";
xml.open('POST', url, true);
xml.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xml.send("score=5&abc=6");

  But,注意一个问题:不同的ajax请求对象,如何保持会话Session/Cookie的问题 

  如果ajax对象不主动设置xml.withCredentials=true(携带Cookie),则Chrome控制台每new XMLHttpRequest()一次ajax请求对象,就是新建一次会话

 

二、Ajax Util工具类设计

  文末处,附属个人的一些笔记的截图(确实值得一阅)。如有不妥之处,还请大家指正,共同进步~

/**
* Ajax Util
*
* @Author JohnnyZen
* @DateTime 2017-11-22
* @copyright [johnny.weily]
* @license [license]
* @version [version]
* @link http://www.johnnyzen.cn/
* @required itemX
*
* @param option { url[,method][,data][,async][,dataType]}
*
* @method 设置option,初始化ajax
* @method complete:请求完成时运行的函数(在请求成功或失败之后均调用,即在success和error函数之后)
* complete:function(responseText,status,event){}
* complete:function(xhr,status){}
* @method success:当请求成功时运行的函数
* success:function(responseText,status,event){}
* success:function(response,status,xhr){}
* @method error:请求出错时候的函数
* error:function(xhr,status,error){}
*
* @notice xhr 用于创建 XMLHttpRequest 对象的函数
* @notice event.target.readyState的各值意义
*
XMLHttpRequest.DONE 4 响应完成或已失败
XMLHttpRequest.LOADING 3 已收到服务器响应
XMLHttpRequest.HEADERS_RECEIVED 2 已收到服务器响应的标头
XMLHttpRequest.OPEND 1 已调用open方法
XMLHttpRequest.UNSENT 0 已创建XMLHttpRequest对象
*/ var Ajax = function(option){
this.option = {
url: null,
type: option.type == undefined ? "GET" : option.type,
async: option.async == undefined ? true : option.async,
data: option.data == undefined ? null : option.data,
contentType: option.contentType == undefined ? option.contentType : "application/x-www-form-urlencoded; charset=UTF-8",
complete: typeof(option.complete) == 'function' ? option.complete : this.defaultCompleteHandle,
success: typeof(option.success) == 'function' ? option.success : this.defaultSuccessHandle,
error:typeof(option.error) == 'function' ? option.error : this.defaultErrorHandle
},
this.createAjaxRequest = function(){
var AjaxRequest = null;// 缓存XHR对象便于 Ajax 使用
try {
// Opera 8.0+, Firefox, Safari
AjaxRequest = new XMLHttpRequest();
} catch (e) { // Internet Explorer Browsers
try {
AjaxRequest = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
try {
AjaxRequest = new ActiveXObject("Microsoft.XMLHTTP");
} catch (e) {
// 错误处理
throw new Error("Your browser broke!");
return false;
}
}
}
return AjaxRequest;
},
this.defaultCompleteHandle = function(responseText,status,event){
console.log("[Ajax#defaultCompleteHandle] responseText:", event.target.responseText); //test
console.log("[Ajax#defaultCompleteHandle] status:", event.target.status); //test
},
this.defaultSuccessHandle = function(responseText,status,event){
console.log("[Ajax#defaultSuccessHandle] responseText:", event.target.responseText); //test
console.log("[Ajax#defaultSuccessHandle] status:", event.target.status); //test
},
this.defaultErrorHandle = function(event){
console.error("defaultErrorHandle:", "ajax request failed!");
},
(function(){
var AjaxRoot = this;//保存当前调用的根对象
var AjaxRequest = AjaxRoot.createAjaxRequest();
try{
AjaxRequest.onreadystatechange = function(event){
//      console.log("option.log:",AjaxRoot.option.log);//test if( event.target.readyState == XMLHttpRequest.DONE){// 4 响应完成或已失败  
console.log('AjaxRoot.option.complete', AjaxRoot.option.complete);
AjaxRoot.option.complete(event.target.responseText,event.target.status,event);
} else if(event.target.readyState == XMLHttpRequest.LOADING){// 3 已收到服务器响应
AjaxRoot.option.success(event.target.responseText,event.target.status,event);
}
}
AjaxRequest.open(AjaxRoot.option.type, AjaxRoot.option.url, AjaxRoot.option.async);
//ajax.open(option.method,option.url,[是否异步请求,默认为true:true],[user],[password]); console.log('AjaxRoot.option.data',AjaxRoot.option.data);//test
AjaxRequest.send(AjaxRoot.option.data);
}catch(e){
console.error(e);
AjaxRoot.option.error();
return false;
}
})();
} //Ajax Util demo
var option = {
type:"GET",
url:"http://apis.baidu.com/beijingprismcubetechnology/qmpapi/qmpproduct",
async:true,//是否异步
dataType:"json",
data:"hello",
complete:function(responseText,status,event){
console.log("complete:",responseText);
}
} Ajax(option);

三、Ajax规范设计者们所提供的接口和一些常见问题的解决方案

JavaScript之Ajax Util的更多相关文章

  1. 最新JavaScript、Ajax典藏级学习资料下载分类汇总 (2011年12月21日更新)

    其他网站开发相关资料            超强HTML和xhtml,CSS精品学习资料下载汇总                                               最新htm ...

  2. 初识JavaScript,Ajax,jQuery,并比较三者关系

    一.基本认识 1.JavaScript 定义: javaScript的简写形式就是JS,是由Netscape公司开发的一种脚本语言,一种广泛用于客户端Web开发的脚本语言,常用来给HTML网页添加动态 ...

  3. JavaScript实现Ajax小结

    置顶文章:<纯CSS打造银色MacBook Air(完整版)> 上一篇:<TCP的三次握手和四次挥手> 作者主页:myvin 博主QQ:851399101(点击QQ和博主发起临 ...

  4. 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求

    转http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro2/ 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求 ...

  5. javascript版Ajax请求

    什么是Ajax请求,Ajax也就是“Asynchronous JavaScript and XML”(异步JavaScript和XML),无刷新数据读取.能减少流量的消耗,也提高了浏览的流畅性,给用户 ...

  6. Javascript与Ajax

    不使用jquery来处理ajax请求该怎么做? 首先要明确html中的某些数据需要从服务端获得,也就是客户端向服务端请求(request)数据,服务端就响应(response)这个请求,把客户端要的数 ...

  7. javascript进阶——Ajax

    统的Web 页面和应用中,用户每点击页面上的某个部分,浏览器就会向服务器发出一个请求,等待服务器做出响应,然后返回一个完整新网页,但在大多数情况下用户不得不忍受页面闪烁和长时间的等待.随着Web技术的 ...

  8. Javascript and AJAX with Yii(在yii 中使用 javascript 和ajax)

    英文原文:http://www.yiiframework.com/wiki/394/javascript-and-ajax-with-yii /*** http://www.yiiframework. ...

  9. javascript实现ajax

    什么是 ajax ajax 即“Asynchronous JavaScript and XML”(异步 JavaScript 和 XML),也就是无刷新数据读取. http 请求 首先需要了解 htt ...

随机推荐

  1. springboot 后台运行

    https://zhuanlan.zhihu.com/p/25102504?refer=dreawer 酱油一篇,整理一下关于Spring Boot后台运行的一些配置方式.在介绍后台运行配置之前,我们 ...

  2. js 正则表达式的使用(标志 RegExp exec() test() compile() $1...$9)

    一,标志 g (global,全局匹配标志) 执行正则表达式匹配或替换时,一般只要搜索到一个符合的文本就停止匹配或替换.使用该标志将搜索所有符合的文本直到文本末尾. i (ignoreCase,忽略大 ...

  3. 【CH6901】骑士放置

    题目大意:给定一个 N*M 的棋盘,有一些格子禁止放棋子.问棋盘上最多能放多少个不能互相攻击的骑士(国际象棋的"骑士",类似于中国象棋的"马",按照" ...

  4. 对PDF的操作

    PDF是个常见的格式,当我们需要对PDF做操作时,可以主要利用PDFbox和itext.这里主要介绍PDfbox,itext自己去 查找资料.添加pom配置. <dependency> & ...

  5. Windows 查看端口占用情况

    今天打算运行一下当年的毕业设计,结果启动ActiveMQ的时候,发现报错 原来是端口占用了.在Windows上怎样看呢? Ctrl+Alt+Del 调出任务管理器 再找到资源监视器 原来是依赖于Erl ...

  6. POJ 1236 Network of Schools (Tarjan)

    Network of Schools Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 22745   Accepted: 89 ...

  7. 4.1、实现4个LED灯同时闪烁

    图中可以看出,P1的0.1.3.4引脚分别连接着4个LED.控制引脚状态,来控制LED. #include "ioCC2530.h" //引用CC2530头文件 /******** ...

  8. 利用sys打印进度条

    在很多常见中,需要对当前处理的进度进行显示,这个时候就需要进度条了,在python中,也有封装好的进度条模块,当然,也可以自己编写一个简单的进度条来帮助理解进度条的实现. 首先,需要理解一个概念,就是 ...

  9. 【转载】Qt之JSON生成与解析

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.它基于JavaScript(Standard ECMA-262 3rd Edition - December ...

  10. mysql常用快速查询修改操作

    mysql常用快速查询修改操作 一.查找并修改非innodb引擎为innodb引擎 # 通用操作 mysql> select concat('alter table ',table_schema ...