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

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

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

2019-11-10 18:39:18
字體:
來源:轉載
供稿:網友

一、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、如果不設置超時,就無法得知此次請求是成功還是失敗;由于代碼有點長,就放個計時器的代碼吧,完整代碼見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
欧美视频专区一二在线观看| 欧美午夜女人视频在线| 一区二区三区视频免费| 国内精品视频一区| 国产美女精品视频| 国产亚洲人成网站在线观看| 国产精品中文字幕在线观看| 日韩日本欧美亚洲| 欧美激情高清视频| 俺也去精品视频在线观看| 在线国产精品视频| 国模极品一区二区三区| 日韩国产欧美区| 亚洲一区二区中文| 日韩av片永久免费网站| 国产91热爆ts人妖在线| 亚洲欧美中文字幕在线一区| 国产亚洲精品va在线观看| 欧美日韩性视频| 青青久久av北条麻妃黑人| 在线精品高清中文字幕| 亚洲国产精品一区二区三区| 国产成人亚洲综合91| 亚洲国产女人aaa毛片在线| 日韩欧美综合在线视频| 九九热99久久久国产盗摄| 黑人巨大精品欧美一区二区免费| 国产91在线视频| 欧美香蕉大胸在线视频观看| 91精品久久久久久久久| 一区二区三区黄色| 亚洲精品福利免费在线观看| 欧美国产日韩一区二区在线观看| 亚洲第一免费播放区| 亚洲二区在线播放视频| 亚洲精品自拍视频| 欧美激情一区二区三级高清视频| 国产亚洲人成网站在线观看| 日韩欧美高清在线视频| 国产欧美最新羞羞视频在线观看| 日韩欧美亚洲综合| 久久久久亚洲精品国产| 国产精品专区h在线观看| 在线电影中文日韩| 国产成人精彩在线视频九色| 日韩av电影在线播放| 成人网在线免费看| 久久精品国产一区| 亚洲久久久久久久久久久| 伊人伊人伊人久久| 欧美激情视频一区二区三区不卡| 国产精品亚洲аv天堂网| 色无极影院亚洲| 黄色一区二区在线| 国产精品亚洲片夜色在线| 欧美成人精品xxx| 国产精品久久久久久久av大片| 亚洲欧美一区二区三区情侣bbw| 色综合色综合网色综合| www.久久撸.com| 亚洲四色影视在线观看| 欧美日本中文字幕| 精品国产91久久久久久老师| 亚洲人成电影在线观看天堂色| 精品国内产的精品视频在线观看| 热久久免费国产视频| 日韩一二三在线视频播| 亚州av一区二区| 97精品国产91久久久久久| 日韩av在线网站| 欧美一性一乱一交一视频| 欧美日韩中文字幕在线视频| 日韩有码视频在线| 亚洲免费电影一区| 这里只有视频精品| 精品久久久在线观看| 国产日韩在线亚洲字幕中文| 久久久这里只有精品视频| 国模视频一区二区三区| 日韩在线观看免费高清完整版| 久久久精品电影| 亲子乱一区二区三区电影| 亚洲精品电影久久久| 国产999在线| 在线不卡国产精品| 国产精品欧美日韩久久| 精品亚洲国产成av人片传媒| 麻豆国产va免费精品高清在线| 亚洲欧美激情在线视频| 久久这里有精品视频| 欧美香蕉大胸在线视频观看| 尤物精品国产第一福利三区| 国产精品夜色7777狼人| 国产精品色悠悠| 亚洲欧美在线x视频| 国产精品人人做人人爽| 日韩国产欧美精品一区二区三区| 国产伦精品一区二区三区精品视频| 欧美精品手机在线| 一区二区三区四区精品| 欧美成人免费在线视频| 91天堂在线观看| 国产精品美女久久久久av超清| 国产精品久久91| 成人自拍性视频| 亚洲天堂av图片| 91人人爽人人爽人人精88v| 久久精品成人欧美大片古装| 亚洲自拍在线观看| 久久人人97超碰精品888| 亚洲国产精品悠悠久久琪琪| 欧美日韩国产综合视频在线观看中文| 美女性感视频久久久| 国产一区av在线| 欧美亚洲激情在线| 日韩精品在线视频美女| 国产亚洲一区精品| 国产精品久久久久久久一区探花| 国产有码一区二区| 国产日韩欧美一二三区| 亚洲欧美日本另类| 久久免费视频在线观看| 中文字幕免费国产精品| 欧美性猛交xxxx免费看漫画| 亚洲第一精品自拍| 77777少妇光屁股久久一区| 国产91ⅴ在线精品免费观看| 亚洲国产成人久久综合| 国产精品直播网红| 日本一区二区三区四区视频| 91免费国产视频| 欧美亚洲另类视频| 日韩h在线观看| 亚洲欧美日韩成人| 日韩一区二区福利| 亚洲女成人图区| 欧美日韩福利电影| 日韩资源在线观看| 久久人人爽人人爽爽久久| 午夜精品一区二区三区在线视| 性欧美在线看片a免费观看| 亚洲一区国产精品| 国产欧美精品一区二区| 日韩欧美有码在线| 欧美性xxxx极品高清hd直播| 国产精品欧美久久久| 国产精品日韩欧美综合| 日韩成人在线免费观看| 亚洲aaaaaa| xvideos亚洲| 欧美激情区在线播放| 影音先锋日韩有码| 久久久亚洲福利精品午夜| 在线亚洲午夜片av大片| 亚洲欧美福利视频| 精品视频—区二区三区免费| 欧美性猛交xxxx偷拍洗澡| 国产69精品久久久久9999| 亚洲男人天堂手机在线| 国产一区二区色| 性欧美长视频免费观看不卡| 精品国产91久久久| 欧美中文字幕视频在线观看| 成人a视频在线观看|