相信Ajax是很多开发人员会使用。自己最开始是使用挺多的后来换使用jQuery了,就很少再使用,不过,最近自己对JavaScript挺上心的,自己也想多研究更深入的知识。就把之前是Ajax从新拿出来练习了下,并进行了下改进。
代码如下:
function Ajax(method,url,flag,content,type,charset){
this.method = method;
this.url = url;
this.flag = flag;
this.content = content;
this.type = type;
this.charset = charset;
this.header = null;
this.value = null;
var xmlHttp = null;
{
try{
// Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
if (xmlHttp.overrideMimeType) {
xmlHttp.overrideMimeType(type);
}
}catch (e){
// Internet Explorer
try{
for( var i = 5; i; i-- ){
try{
if( i != 2 ){
xmlHttp = new ActiveXObject( "Msxml2.XMLHTTP." + i + ".0" );
}
xmlHttp.setRequestHeader("Content-Type",type);
xmlHttp.setRequestHeader("Content-Type",charset);
break;
}catch(e){
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}
}
}catch(e2){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}catch(e3){
alert("您的浏览器不支持AJAX!");
xmlHttp = null;
}
}
}
this.xmlHttp = xmlHttp;
}
this.onReady = function(xmlHttp){
xmlHttp.onreadystatechange=function(){
//alert(xmlHttp.readyState);
if(xmlHttp.readyState==0){
//请求未初始化(在调用 open() 之前)
//alert("请求未初始化(在调用 open() 之前)");
}else if(xmlHttp.readyState==1){
//请求已提出(调用 send() 之前)
//alert("请求已提出(调用 send() 之前)");
}else if(xmlHttp.readyState==2){
// 请求已发送(这里通常可以从响应得到内容头部)
//alert("请求已发送(这里通常可以从响应得到内容头部)");
}else if(xmlHttp.readyState==3){
// 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
//alert("请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)");
}else if(xmlHttp.readyState==4){
// 请求已完成(可以访问服务器响应并使用它)
//alert("请求已完成(可以访问服务器响应并使用它)");
if (xmlHttp.status == 200){
alert(xmlHttp.responseText);
}
}
}
}
//终止当前请求;
this.sTop =function(){
xmlHttp.abort();
}
//把HTTP所以响应首部作为键/值对返回;
this.getAllResponseHeaders=function(){
return xmlHttp.getAllResponseHeaders();
}
//返回指定首部的串值;
this.getResponseHeader=function (header){
return xmlHttp.getResponseHeader(header);
}
//把指定首部设置为所提供的值。在设置任何首部之前必须先调用open()
this.setRequestHeader = function(header,value){
xmlHttp.setRequestHeader(header,value);
}
//处理下默认参数不存在的情况
this.process = function(){
if(this.flag==null||this.flag=="undefined"||this.flag==""){
this.flag = true;
}
if(this.content==null||this.content=="undefined"||this.content==""){
this.content = null;
}
if(this.type==null||this.type=="undefined"||this.type==""){
this.type = "text/xml";
}
if(this.charset==null||this.charset=="undifind"||this.charset==""){
this.charset = "utf-8";
}
if(this.method==null||this.method=="undefined"||this.method==""){
this.method = "POST";
}
}
//一个是指示所用方法(通常是GET或POST,PUT很少用)的串,另一个是表示目标资源URL的串,
//还有一个Boolean值,指示请求是否是异步的。
this.processRequest = function(){
this.process();
if(xmlHttp!=null){
this.onReady(xmlHttp);
xmlHttp.open(this.method,this.url,this.flag);
xmlHttp.send(this.content);
}else{
alert("您的浏览器不支持ajax!");
}
}
//------------无参数-----------------------
this.request=function(){
this.processRequest();
}
//------------有参数-----------------------
this.requestWithParams=function(method,url,flag,content,type,charset){
this.method = method;
this.url = url;
this.flag = flag;
this.content = content;
this.type = type;
this.charset = charset;
this.processRequest();
}
}
不再是像以前那样直接的把各个函数(function )写成同一级别的代码段相互调用,而是类似于Java的对象形式;
有了上面的js,就可以在页面简单的进行调用了;
首先当然是导入js文件了:
<script type="text/javascript" language="javascript" src="ajax.js"></script>
然后就是来使用了,为了灵活化,我写了两种方式;
第一种:
<script type="text/javascript">
var url = "areq.xml";
var content = "";
var ajax = new Ajax("POST",url,true,content,'text/xml',"utf-8");
ajax.request();
</script>
第二种:
<script type="text/javascript">
var url = "areq.xml";
var content = "";
var ajax = new Ajax();
ajax.requestWithParams("POST",url,true,content,'text/xml',"utf-8");
</script>
同样也可以从ajax里面取得一些属性自己进行实现,比如:
<script type="text/javascript">
var url = "areq.xml";
var content = "";
var ajax = new Ajax("POST",url,true,content,'text/xml',"utf-8");
ajax.request();
//var ajax = new Ajax();
//ajax.requestWithParams("POST",url,true,content,'text/xml',"utf-8");
alert(ajax.xmlHttp);
var headers = ajax.xmlHttp.getAllResponseHeaders();
alert(headers.length);
</script>
因为我不知道自己最终将会做一个什么样的效果,可能会加上请求过程中给用户展示一些页面效果,也可能会屏蔽屏幕。
所以如果你要借鉴上面的js你必须实现你自己的处理,即对js进行完善:
完善js中的下面代码段:
this.onReady = function(xmlHttp){
xmlHttp.onreadystatechange=function(){
//alert(xmlHttp.readyState);
if(xmlHttp.readyState==0){
//请求未初始化(在调用 open() 之前)
//alert("请求未初始化(在调用 open() 之前)");
}else if(xmlHttp.readyState==1){
//请求已提出(调用 send() 之前)
//alert("请求已提出(调用 send() 之前)");
}else if(xmlHttp.readyState==2){
// 请求已发送(这里通常可以从响应得到内容头部)
//alert("请求已发送(这里通常可以从响应得到内容头部)");
}else if(xmlHttp.readyState==3){
// 请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)
//alert("请求处理中(响应中通常有部分数据可用,但是服务器还没有完成响应)");
}else if(xmlHttp.readyState==4){
// 请求已完成(可以访问服务器响应并使用它)
//alert("请求已完成(可以访问服务器响应并使用它)");
if (xmlHttp.status == 200){
alert(xmlHttp.responseText);
}
}
}
}
分享到:
相关推荐
一个简单实用的javascript AJAX 工具类; 简单应用的时候, 你不需导入像prototype,jQuery那样大的类库
在压缩包中的`ajax_util.js`文件很可能是这个自定义Ajax工具的源代码,而`readme.txt`文件可能包含了使用说明、示例代码或者关于工具的一些额外信息,例如如何引入、如何调用其方法、注意事项等。 总的来说,这个小...
JavaScript 后台调用工具类是一种实用的编程资源,它为开发者提供了在后台环境中使用 JavaScript 进行操作的便利。这个工具类旨在简化JavaScript代码,让开发者能够更高效地进行项目开发,尤其对于不熟悉JavaScript...
本压缩包包含了Ajax工具的详细说明,可能包括Ajax库的安装指南、示例代码、使用教程以及相关的调试技巧。通过学习和实践,你可以熟练掌握Ajax技术,提升Web应用的交互性和用户体验。 总之,Ajax技术是现代Web开发中...
标题中的“ajax js和java封装好的工具”指的是一个已经整合了AJAX、JavaScript以及Java的工具包,方便开发者在基于Struts2框架的应用中快速实现异步数据交互功能。Struts2是一个流行的Java web框架,它允许开发人员...
**Ajax工具核心组件详解** Ajax(Asynchronous JavaScript and XML)技术是现代Web开发中的关键组成部分,...在实际开发中,选择合适的JavaScript库和Ajax工具,结合良好的编程实践,可以显著提高开发效率和代码质量。
AjaxTools是一款专为后台开发者设计的便捷工具集合,旨在简化JavaScript中的AJAX(Asynchronous JavaScript and XML)开发,提高开发效率。它包含了一系列实用的函数和类,帮助开发者快速处理异步数据请求,实现网页...
在“实体类反射非空赋值,AjaxJson工具类”这个主题中,我们将探讨如何使用反射来安全地为实体类的属性赋值,并结合Ajax与JSON进行数据的转换和交互。 首先,让我们深入了解反射的概念。Java反射API提供了Class类,...
总的来说,MicrosoftAjax.js为.NET开发者提供了一个强大且易用的Ajax实现工具,使得在ASP.NET环境中构建动态、交互性强的Web应用变得更加便捷。它集成了完整的生命周期管理、错误处理、状态维护等功能,极大地提高了...
总结来说,这个"js版分页类,ajax效果无刷新"是一个使用JavaScript和AJAX技术实现的轻量级分页解决方案,旨在提高网页加载速度和用户体验。通过学习和理解这个示例,开发者可以更好地掌握动态加载数据和页面局部更新...
这里我们关注的“mymvc自己写的ajax框架”显然是一款基于MVC(Model-View-Controller)模式构建的个人项目,它允许开发者通过Ajax技术实现页面的异步更新,提高用户体验,同时保持服务器负载均衡。以下将详细介绍...
在这个名为“自己写的一些东西,包含java工具类,js插件类,小游戏等等”的压缩包文件中,我们可以发现丰富的IT知识资源,主要集中在Java编程语言和JavaScript领域。下面将详细阐述这两个领域的相关知识点。 首先,...
uni-app 自己封装的utils.js 常用工具类(封装的ajax,上传,查看文档,富文本解析)
8. "Util.js":这是一个可能包含实用函数的JavaScript文件,可能包括对AJAX操作的封装,是实际开发中常见的工具类库。 综上所述,学习和掌握AJAX的使用以及JavaScript的类库封装,不仅需要理解JavaScript的基本概念...
在调试JavaScript时,可以使用内置的开发者工具或者Internet Explorer的调试器,设置断点进行单步调试。 总的来说,IntelliJ IDEA与AJAX的结合为Web开发提供了高效、智能的环境,通过合理配置和熟练使用其各种功能...
在"AjaxHelper.js"中,可能定义了一个JavaScript函数库,用于实现AJAX请求。这个库可能包括了创建XMLHttpRequest对象,设置HTTP请求方法(GET或POST),处理响应数据,以及触发异步请求的方法。在Web开发中,AJAX常...
JavaScript(Js)与Ajax(异步JavaScript和XML)的交互是Web开发中的核心技术,它使得网页无需刷新就能实现与服务器的数据交换,极大地提升了用户体验。本文将深入探讨Js与Ajax的交互原理、应用场景以及实现方法。 ...
在提供的文件列表中,`index.htm`很可能是用来展示如何使用这个Ajax类的示例页面,而`ajaxDom.js`则可能是包含了这个Ajax类的JavaScript文件。通过查看这两个文件,我们可以更具体地了解这个Ajax类的实现细节和使用...
一般在浏览器中查看页面代码 是浏览器直接下载到的页面代码 在未经渲染前 对于JS AJAX输出的内容是无法得到的 这样我们得到的页面内容和直接走socket抓取回来无任何区别 还是无法得到需要的页面内容。 JS函数及页面...
**Ajax工具包**是开发人员在构建Web应用程序时用于简化Ajax实现的集合,它们通常包含一系列预先封装好的组件和函数,方便开发者快速构建具有Ajax功能的界面。在本例中提到的是**AjaxControlToolkit**,这是一个非常...