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

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

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

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

一、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事件處理函數才能確保跨瀏覽器兼容性。

三、同域發送請求

①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
一本一本久久a久久精品牛牛影视| 国产亚洲欧美aaaa| 欧美大片在线看免费观看| 久久久久久免费精品| 国产精品流白浆视频| 成人深夜直播免费观看| 色偷偷噜噜噜亚洲男人| 欧美激情一级欧美精品| 97视频在线播放| 91精品久久久久久久久中文字幕| 精品久久久久久久久国产字幕| 日韩电视剧免费观看网站| 欧美成人三级视频网站| 91精品啪aⅴ在线观看国产| 久久久久国产视频| 欧美激情第6页| 欧美精品videossex88| 国产成人亚洲综合青青| 亚洲电影免费观看高清完整版在线| 久久久精品免费| 爽爽爽爽爽爽爽成人免费观看| 国产精品美女在线观看| 国产精自产拍久久久久久蜜| 日韩精品视频三区| 最近免费中文字幕视频2019| 欧美日韩性视频| 欧美国产亚洲精品久久久8v| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲精品久久7777777| 欧美精品制服第一页| 综合网中文字幕| 亚洲成人久久电影| 日韩国产高清污视频在线观看| 亚洲国产成人久久| 奇米4444一区二区三区| 一本大道香蕉久在线播放29| 欧美日本啪啪无遮挡网站| 日韩av在线直播| 欧美精品手机在线| 亚洲人成伊人成综合网久久久| 在线观看日韩欧美| 久久精品亚洲热| 亚洲永久在线观看| 激情久久av一区av二区av三区| 九九久久久久99精品| 亚洲精品电影在线观看| 国产成人精品一区二区在线| 日韩福利在线播放| 青青久久aⅴ北条麻妃| 456国产精品| 久久久久久久久久av| 久久免费在线观看| 欧美性猛交丰臀xxxxx网站| 91影院在线免费观看视频| www日韩欧美| 欧美日韩一区二区免费在线观看| 69**夜色精品国产69乱| 91精品国产综合久久香蕉922| 日本久久久久亚洲中字幕| 日韩在线中文字| 91精品久久久久久久久久久久久久| 亚洲欧美中文另类| 怡红院精品视频| 国产精品免费看久久久香蕉| 久久精品小视频| 国产精品成人品| 国产色视频一区| 2019亚洲日韩新视频| 黄色成人在线播放| 尤物九九久久国产精品的特点| 亚洲一区二区三区久久| 国产午夜精品一区二区三区| 午夜精品视频网站| 久久久久久久久久久免费| 正在播放欧美视频| 欧美日韩国产影院| 亚洲欧美日韩国产成人| 日韩视频永久免费观看| 91精品视频在线| 国产精品美女免费视频| 精品自在线视频| 日本亚洲精品在线观看| 91久久综合亚洲鲁鲁五月天| 国产欧美一区二区三区视频| 久久琪琪电影院| 色多多国产成人永久免费网站| 欧美成人免费在线视频| 国产亚洲精品一区二区| 亚洲男人第一网站| 亚洲电影在线观看| 97久久伊人激情网| 少妇精69xxtheporn| 欧美在线免费视频| 91久久国产精品91久久性色| 国产精品视频不卡| 欧美激情精品久久久久久黑人| 日韩在线观看免费高清| 欧美电影免费观看大全| 亚洲国产美女久久久久| 日韩最新在线视频| 久久久久久久久久久人体| 精品国产91久久久久久老师| 国产精品黄色影片导航在线观看| 在线观看视频99| 色与欲影视天天看综合网| 黑人狂躁日本妞一区二区三区| 韩国日本不卡在线| 欧美视频免费在线| 亚洲一区av在线播放| 成人午夜在线观看| 91av中文字幕| 国产精品美女www| 欧美激情视频三区| 韩日精品中文字幕| 欧美大片欧美激情性色a∨久久| 国产精品久久999| 91亚洲精品久久久久久久久久久久| 欧美大片在线看免费观看| 日韩av片免费在线观看| 亚洲精品视频播放| 国产精品亚发布| 日韩美女视频免费看| 亚洲精品wwww| 欧美激情xxxx性bbbb| 亚洲影视九九影院在线观看| 国产精品日韩欧美| 欧美性猛交99久久久久99按摩| 欧美激情女人20p| 成人免费网站在线观看| 国产精品999999| 91日本视频在线| 国产精品视频最多的网站| 欧美成人精品一区二区三区| 国产乱人伦真实精品视频| 亚洲精品xxx| 国产精品福利网站| 91极品女神在线| 性日韩欧美在线视频| 久久久国产一区二区三区| 欧美xxxwww| 国产精品永久在线| 色综合91久久精品中文字幕| 精品亚洲aⅴ在线观看| 国产亚洲精品久久久优势| 国产精品电影观看| 成人av在线网址| 久久久久久久久久国产| 久久精品成人欧美大片| 色偷偷91综合久久噜噜| 亚洲午夜av久久乱码| 爽爽爽爽爽爽爽成人免费观看| 日本中文字幕不卡免费| 亚洲97在线观看| 日韩av理论片| 亚洲欧美综合另类中字| 日韩视频欧美视频| 日韩精品极品在线观看| 国产一区二区三区视频免费| 欧洲s码亚洲m码精品一区| 日韩大片在线观看视频| 久久久999精品视频| 91中文字幕在线观看| 日韩在线观看网址| 欧美又大粗又爽又黄大片视频|