javascript:以前寫的xmlhttp池,代碼
更新時(shí)間:2008年05月18日 21:42:33 作者:
用javascript寫的xmlhttp池代碼,最下面有調(diào)用方法
var Pool_xmlreq=function(){
var _cacheCase=[];
_cacheCase.fetch=function(){
var i=0;
var _instance=function(){
try{
return (new ActiveXObject("Msxml2.XMLHTTP.5.0"));}
catch(e){
try{
return (new XMLHttpRequest());}
catch(e){
try{
return (new ActiveXObject("Msxml2.XMLHTTP"));}
catch(e){
try{
return (new ActiveXObject("Microsoft.XMLHTTP"));}
catch(e){
alert("Error: initializing xmlhttprequest!");}}}}}
for(;i<this.length;i++){
if(this[i].readyState==0||this[i].readyState==4){
return this[i];}}
this[i]=_instance();
return this[i];}
this.length=function(){
return _cacheCase.length}
this.instance=function(){
return _cacheCase.fetch()}
this.connect=function(method,url,data,handler){
var _xmlhttpreq=_cacheCase.fetch();
with(_xmlhttpreq){
open(method,url,true);
setRequestHeader("Cache-Control","no-cache");
setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=UTF-8");
send(data);
onreadystatechange=function(){
if(_xmlhttpreq.readyState<4)
return false;
if(_xmlhttpreq.status==200||_xmlhttpreq.status==304){
handler(decodeURIComponent(_xmlhttpreq.responseText));
return true;}
alert("Error: status_"+_xmlhttpreq.status+"!");
return false;}}}
}
var xmlreq=new Pool_xmlreq();
用法:
xmlreq.connect("post",url,postdata,function);
var _cacheCase=[];
_cacheCase.fetch=function(){
var i=0;
var _instance=function(){
try{
return (new ActiveXObject("Msxml2.XMLHTTP.5.0"));}
catch(e){
try{
return (new XMLHttpRequest());}
catch(e){
try{
return (new ActiveXObject("Msxml2.XMLHTTP"));}
catch(e){
try{
return (new ActiveXObject("Microsoft.XMLHTTP"));}
catch(e){
alert("Error: initializing xmlhttprequest!");}}}}}
for(;i<this.length;i++){
if(this[i].readyState==0||this[i].readyState==4){
return this[i];}}
this[i]=_instance();
return this[i];}
this.length=function(){
return _cacheCase.length}
this.instance=function(){
return _cacheCase.fetch()}
this.connect=function(method,url,data,handler){
var _xmlhttpreq=_cacheCase.fetch();
with(_xmlhttpreq){
open(method,url,true);
setRequestHeader("Cache-Control","no-cache");
setRequestHeader("Content-Type","application/x-www-form-urlencoded;charset=UTF-8");
send(data);
onreadystatechange=function(){
if(_xmlhttpreq.readyState<4)
return false;
if(_xmlhttpreq.status==200||_xmlhttpreq.status==304){
handler(decodeURIComponent(_xmlhttpreq.responseText));
return true;}
alert("Error: status_"+_xmlhttpreq.status+"!");
return false;}}}
}
var xmlreq=new Pool_xmlreq();
用法:
xmlreq.connect("post",url,postdata,function);
相關(guān)文章
深入學(xué)習(xí)JavaScript ES8中的函數(shù)式編程
函數(shù)式編程已經(jīng)成為現(xiàn)代JavaScript開發(fā)中的一種主要范式,它提供了一種更清晰、更模塊化、更可維護(hù)的代碼編寫方式,本文將深入探討ES8中的一些關(guān)鍵特性,并演示如何使用這些特性進(jìn)行函數(shù)式編程實(shí)踐,有需要的可以參考下2023-09-09
基于JavaScript實(shí)現(xiàn)下拉列表左右移動(dòng)代碼
這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)下拉列表左右移動(dòng)效果,代碼簡單易懂非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02
學(xué)習(xí)JavaScript編程語言的8張思維導(dǎo)圖分享
這篇文章主要介紹了學(xué)習(xí)JavaScript編程語言的8張思維導(dǎo)圖分享,本文給出了javascript變量、javascript運(yùn)算符、javascript數(shù)組、javascript流程語句、javascript字符串函數(shù)、javascript函數(shù)基礎(chǔ)、javascript基礎(chǔ)DOM操作、javascript正則表達(dá)式的思維導(dǎo)圖,需要的可以參考下2015-03-03
前端小知識(shí)之??=?操作符更簡潔的默認(rèn)值處理方式
這篇文章主要介紹了前端小知識(shí)之??=?操作符更簡潔的默認(rèn)值處理方式的相關(guān)資料,??=操作符是JavaScript中用于設(shè)置默認(rèn)值的新操作符,它僅在變量值為null或undefined時(shí)才賦值,需要的朋友可以參考下2024-11-11
ES2020讓代碼更優(yōu)美的運(yùn)算符 (?.) (??)
這篇文章主要介紹了ES2020讓代碼更優(yōu)美的運(yùn)算符 (?.) (??),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

