亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

JS封裝Ajax插件(同域&&jsonp跨域)

2019-11-10 17:55:49
字體:
來源:轉載
供稿:網友

一、Ajax核心,創建XHR對象

Ajax技術的核心是xmlHttPRequest對象(簡稱XHR),IE5是第一款引入XHR對象的瀏覽器,而IE5中的XHR對象是通過MSXML庫中的一個ActiveX對象實現的,因此在IE中可能有3個版本,即MSXML2.xmlhttp、MSXML2.XMLHttp.3.0和MSXML2.XMLHttp.6.0。所以創建XHR對象的時候要用兼容性寫法:

12345678910111213141516171819createXHR:function(){    if(typeof XMLHttpRequest!='undefined'){    return new XMLHttpRequest();    }else if(typeof ActiveXObject!='undefined'){    if(typeof arguments.callee.activeXString!='string'){        var versions=["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0","MSXML2.XMLHttp"],i,len;        for(i=0,len=versions.length;i<len;i++){        try{            new ActiveXObject(versions[i]);            arguments.callee.activeXString=versions[i];            break;        }catch(ex){        }        }        return new ActiveXObject(arguments.callee.activeXString);        }else{        throw new Error("No XHR object available.");    }}

二、XHR的主要方法屬性

方法:

open()方法:接受3個參數,要發送的請求的類型、請求的URL、是否異步發送的布爾值

send()方法:要作為請求主體發送的數據,如果不需要通過請求主體發送數據,則必須傳入null

abort()方法:在接收到響應之前調用來取消異步請求。

屬性:

responseText:作為響應主體被返回的文本。

status:響應的HTTP狀態

statusText:HTTP狀態說明

readyState:表示請求/響應過程的當前活動階段

取值分別為:

0:未初始化。尚未調用open()方法

1:啟動。已經調用open()方法,但尚未調用send()方法

2:發送。已經調用send()方法,但未接收到響應。

3:接收。已經接受到部分響應數據

4:完成。已經接受到全部響應數據,而且已經可以在客戶端使用了。

 

本例中的onreadystatechange事件處理函數:

123456789101112131415var complete=function(){    if(xhr.readyState==4){     if((xhr.status>=200&&xhr.status<300)||xhr.status==304){        if(params.success){         params.success(xhr.responseText);//執行調用ajax時指定的success函數         }    }else{        if(params.fail){        params.fail();//執行調用ajax時指定的fail函數       }else{        throw new Error("Request was unsucessful:"+xhr.status);       }    }    }}

注意:必須在調用open()方法之前指定onreadystatechange事件處理函數才能確??鐬g覽器兼容性。

三、同域發送請求

①GET請求

最常見的請求類型,常用于查詢某些信息。通過將查詢的字符串參數追加到URL的末尾來將信息發送給服務器。get方法請求需要注意的是,查詢字符串中的每個參數名稱和值都必須使用encodeURIComponent()進行編碼,而且所有名-值對都必須由&號分割。

請求方法:

12345678if((this.config.type=="GET")||(this.config.type=="get")){   for(var item in this.config.data){    this.config.url=addURLParam(this.config.url,item,this.config.data[item]);//使用encodeURIComponent()進行編碼    }   xhr.onreadystatechange=complete;   xhr.open(this.config.type,this.config.url,this.config.async);   xhr.send(null);}

②POST請求

通常用于向服務器發送應該被保存的數據,POST請求應該把數據作為請求的主體提交。這里將模仿表單提交。即將Content-Type頭部信息設置為application/x-www-form-urlencoded; charset=UTF-8。

序列化函數:

復制代碼 
    function serialize(data){        var val="";        var str="";        for(var item in data){            str=item+"="+data[item];            val+=str+'&';        }        return val.slice(0,val.length-1);    } 復制代碼

請求方法:

復制代碼 
if(this.config.type=="POST"||this.config.type=="post"){       xhr.addEventListener('readystatechange',complete);       xhr.open(this.config.type,this.config.url,this.config.async);       if(params.contentType){            this.config.contentType=params.contentType;          }        xhr.setRequestHeader("Content-Type",this.config.contentType);        xhr.send(serialize(this.config.data));} 復制代碼

兩個請求的一些區別:

 ①GET請求把參數數據寫到URL中,在URL中可以看到,而POST看不到,所以GET不安全,POST較安全。

②GET傳送的數據量較小,不能大于2kb。POST傳送的數據量較大,一般默認為不受限制。

③GET服務器端用Request.QueryString來獲取變量的值,POST服務器端用Request.From來獲取。

④GET將數據添加到URL中來傳遞到服務器,通常利用一個?,后面的參數每一個數據參數以“名稱=值”的形式出現,參數與參數之間利用一個連接符&來區分。POST的數據是放在HTTP主體中的,其組織方式不只一種,有&鏈接方式,也有分隔符方式??梢噪[藏參數,傳遞大批數據,比較方便。

三、jsonp跨域發送請求

 首先,跨域是神馬情況呢?

一個域名的組成:

http://     www  .  abc.com:   8080  / scripts/AjaxPlugin.js

協議       子域名      主域名      端口號     請求資源地址

~當協議、子域名、主域名、端口號中任意一個不相同時,都算作不同域。

~不同域之間互相請求資源,就算作“跨域”。

所有的瀏覽器都遵守同源策略,這個策略能夠保證一個源的動態腳本不能讀取或操作其他源的http響應和cookie,這就使瀏覽器隔離了來自不同源的內容,防止它們互相操作。所謂同源是指協議、域名和端口都一致的情況。瀏覽器會阻止ajax請求非同源的內容。

JSONP(JSON with Padding) 是一種跨域請求方式。主要原理是利用了script 標簽可以跨域請求的特點,由其 src 屬性發送請求到服務器,服務器返回 JS 代碼,網頁端接受響應,然后就直接執行了,這和通過 script 標簽引用外部文件的原理是一樣的。但是jsonp跨域只支持get請求。

JSONP由兩部分組成:回調函數和數據,回調函數一般是由網頁端控制,作為參數發往服務器端,服務器端把該函數和數據拼成字符串返回。

jsonp跨域主要需要考慮三個問題:

1、因為 script 標簽的 src 屬性只在第一次設置的時候起作用,導致 script 標簽沒法重用,所以每次完成操作之后要移除;

2、JSONP這種請求方式中,參數依舊需要編碼;

3、如果不設置超時,就無法得知此次請求是成功還是失?。挥捎诖a有點長,就放個計時器的代碼吧,完整代碼見AjaxPlugin
12345678//超時處理if(params.time){   scriptTag.timer=setTimeout(function(){       head.removeChild(scriptTag);       params.fail&&params.fail({message:"over time"});       window[cbName]=null;    },params.time);}

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
情事1991在线| 国产日韩在线看| 日韩精品视频观看| 日韩电视剧在线观看免费网站| 国产精品白丝jk喷水视频一区| 亚洲国产福利在线| 亚洲永久免费观看| 亚洲一区二区久久久| 久久精品91久久香蕉加勒比| 色偷偷91综合久久噜噜| 久久综合88中文色鬼| 欧美视频在线视频| 欧美亚洲伦理www| 久久夜色精品国产亚洲aⅴ| 91免费国产网站| 国产精品日韩久久久久| 色樱桃影院亚洲精品影院| 国产视频久久久久久久| 欧美日韩亚洲一区二区三区| 亚洲国产精品999| 久久久人成影片一区二区三区| 国产z一区二区三区| 欧洲成人免费视频| 欧美大片欧美激情性色a∨久久| 2019日本中文字幕| 欧美一级黑人aaaaaaa做受| 中文字幕日韩在线视频| 69久久夜色精品国产69| 在线播放亚洲激情| 久久久噜噜噜久久中文字免| 日韩美女写真福利在线观看| 亚洲r级在线观看| 日产精品久久久一区二区福利| 欧美日韩福利电影| 亚洲第一页中文字幕| 乱亲女秽乱长久久久| 久久精品国产成人| 国产aaa精品| 亚洲最大福利网站| 国产精品网红直播| 国产精品久久久久久久久久三级| 欧美性猛交xxxx偷拍洗澡| 2023亚洲男人天堂| 久久久久久久爱| 欧洲s码亚洲m码精品一区| 亚洲一区二区久久久久久久| 欧美成人三级视频网站| 亚洲精品国产精品乱码不99按摩| 日本欧美一二三区| 亚洲欧美日韩视频一区| 亚洲国语精品自产拍在线观看| 国产精品美女无圣光视频| 欧美视频在线观看免费网址| 日本久久亚洲电影| 78色国产精品| 一本色道久久综合亚洲精品小说| 亚洲欧美国产高清va在线播| 日韩国产高清污视频在线观看| 日韩电影免费观看在线观看| 另类专区欧美制服同性| 欧美伊久线香蕉线新在线| 国内精品美女av在线播放| 久久亚洲国产精品成人av秋霞| 91成人国产在线观看| 久久精品电影网站| 国产免费成人av| 国产精品成人国产乱一区| 亚洲精品不卡在线| 91色视频在线观看| 色综合久久久久久中文网| 日本欧美一二三区| 亚洲伊人久久综合| 国产精品香蕉av| 亚洲国产精彩中文乱码av| 国产成人一区二区在线| 精品国产鲁一鲁一区二区张丽| 日韩av在线最新| 久久久99久久精品女同性| 亚洲精品国产综合久久| 国外日韩电影在线观看| 精品国产福利视频| 日韩高清免费在线| 色综合亚洲精品激情狠狠| 欧美日韩在线视频一区二区| 青青青国产精品一区二区| 国产剧情日韩欧美| 欧美在线一区二区视频| 国产精品视频一区二区高潮| 91亚洲国产精品| 欧美久久精品一级黑人c片| 国产成人精品免费久久久久| 国产小视频国产精品| 宅男66日本亚洲欧美视频| 日韩av成人在线| 国产男女猛烈无遮挡91| 中文字幕国产精品| 国产免费一区二区三区香蕉精| 91av在线免费观看视频| 国产乱肥老妇国产一区二| 在线播放国产一区二区三区| 久久久黄色av| 亚洲欧美一区二区三区久久| 国产精品久久久久久久9999| 色婷婷综合成人av| 伊人久久大香线蕉av一区二区| 亚洲一区二区三区视频| 91精品国产综合久久香蕉922| 久久亚洲精品视频| 成人黄色av网| 在线视频日本亚洲性| 日韩人体视频一二区| 精品伊人久久97| 精品激情国产视频| 日韩精品在线观| 98精品国产自产在线观看| 2019亚洲男人天堂| 高清视频欧美一级| 久久香蕉国产线看观看网| 91伊人影院在线播放| 久久久久成人精品| 亚洲精品乱码久久久久久按摩观| 日韩在线免费视频观看| 成人av电影天堂| 中文字幕欧美精品在线| 亚洲国产高清高潮精品美女| 啊v视频在线一区二区三区| 久久精品99无色码中文字幕| 自拍偷拍亚洲欧美| 97欧美精品一区二区三区| 高跟丝袜欧美一区| 欧美成人免费网| 亚洲视频在线免费观看| 国产精品视频一区国模私拍| 成人激情视频在线观看| 欧美一级电影在线| 欧美日韩日本国产| 38少妇精品导航| 久久久精品美女| 亚洲精品国精品久久99热一| 国产精品wwww| 日韩美女视频在线观看| 91精品国产色综合久久不卡98| 一本色道久久综合亚洲精品小说| 亚洲精品在线不卡| 亚洲欧美中文字幕| 欧美大片免费观看在线观看网站推荐| 尤物tv国产一区| 国产精品男人爽免费视频1| 精品福利在线观看| 国产精品久久久久久五月尺| 亚洲综合色av| 国产精品午夜国产小视频| 成人淫片在线看| 亚洲最大av网站| 国产一区二区激情| 疯狂做受xxxx高潮欧美日本| 日本三级韩国三级久久| 欧美激情一区二区三区在线视频观看| 国产精品视频999| 精品久久久久久中文字幕大豆网| 色综合伊人色综合网站| 亚洲激情在线观看视频免费| 久久综合久久88| 亚洲国产精品999|