ajax小結(jié)

在平時的開發(fā)項目中,難免接觸前端的知識,需要寫接口,有時候用到j(luò)s中的ajax跨越請求,總結(jié)了ajax的寫法。

開始之前,需要準備兩個文件,ajax.php ;ajax.html

1.ajax的基本步驟(ajax.php)

//1.創(chuàng)建對象
    var ajax = new XMLHttpRequest();
    // alert(typeof ajax);

//2.建立連接
ajax.open('get', 'ajax.php?id=5', true);

//3.發(fā)送請求
ajax.send();

//4.準備事件處理結(jié)果
ajax.onreadystatechange = function()
{
    if (ajax.readyState == 4 && ajax.status == 200) {
        //請求: request
        //響應: response
        var res = ajax.responseText;

        // alert(res);
        document.write(res);
    }
}

ajax,有同步異步的區(qū)別?異步:把小弟派出去了,什么時候回來,什么時候處理它,主程序繼續(xù)執(zhí)行,不會等待。同步:(比較少用)會在send這一步等待,主程序不會繼續(xù)執(zhí)行。method:請求的類型;GET 或 POST 。

2.ajax封裝為函數(shù)(ajax.php)

<script>
 function get(url, func)
 {
     var ajax = new XMLHttpRequest();
     ajax.open('get', url, true);
     ajax.send();
     ajax.onreadystatechange = function()
     {
         if (ajax.readyState == 4 && ajax.status == 200) {
             var res = ajax.responseText;

             func(res);
         }
     }
 }

 //回調(diào) + 匿名
 get('1.php', function(res){
     alert(res);
 })

 get('ajax.php', function(res){
     console.log(res);
 })

/*
 get('1.php', chuli);
 function chuli(res)
 {
     alert(res);
 }

 get('ajax.php', chuli2);
 function chuli2(res)
 {
     console.log(res);
 }
 */
</script>

這樣封裝好,就方便我們使用了,tp框架,ecshop,ecstore,都有自己的封裝的ajax。

3.jq中的ajax請求(ajax.php)

$.ajax({
     url: 'ajax.php?id=5',
     dataType: 'json',    //指定返回數(shù)據(jù)的類型:xml, html, script, json, text, _default (不要騙他)
     type: 'get',    //設(shè)置請求的類型:get(默認) post
     // data: 'name=123&age=18',    //傳輸?shù)臄?shù)據(jù)(有兩種格式)
     data: {age:8},    //傳輸?shù)臄?shù)據(jù)
     async: true,    //同步異步:true 默認異步     false 同步 
     success: function(res) {
         // alert(typeof res);
         // alert(res.id);
         alert(123);
     },
     error: function(a){
         alert('出錯鳥~~~');
     }
 });

4.ajax跨域問題(ajax.php)

協(xié)議、域名、端口這三個有任何一個不同,就跨域了。ajax本身是不可以跨域的,通過產(chǎn)生一個script標簽來實現(xiàn)跨域。因為script標簽的src屬性是沒有跨域的限制的。其實設(shè)置了dataType: 'jsonp'后,$.ajax方法就和ajax XmlHttpRequest沒什么關(guān)系了,取而代之的則是JSONP協(xié)議。JSONP是一個非官方的協(xié)議,它允許在服務器端集成Script tags返回至客戶端,通過javascript callback的形式實現(xiàn)跨域訪問。

實現(xiàn)ajax的跨域請求,有幾種方法,這兒寫一種通過‘jsonp’,實現(xiàn)跨域的方法

<script type="text/javascript">     
   var url = 'http://localhost/other.php?act=get_article';
$.ajax({
    type : "get",
    url :url, 
    jsonp: "callbackparam",
    jsonpCallback:"jsonpCallback1",
    success : function(data){
        var obj = eval(data);
        //處理接收到的數(shù)據(jù)
    },
    //end
    error:function(e){
        alert("error");
    }
});                
</script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,406評論 6 538
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,034評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,413評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,449評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,165評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,559評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,606評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,781評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,327評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,084評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,278評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,849評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,495評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,927評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,172評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,010評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,241評論 2 375

推薦閱讀更多精彩內(nèi)容

  • AJAX 原生js操作ajax 1.創(chuàng)建XMLHttpRequest對象 var xhr = new XMLHtt...
    碧玉含香閱讀 3,247評論 0 7
  • Ajax的基本概念及使用 同步&異步 同步:必須等待前面的任務完成,才能繼續(xù)后面的任務; 異步:不受當前主要任務的...
    magic_pill閱讀 1,969評論 0 5
  • 原文出處 http://blog.poetries.top/2016/11/26/Ajax-summary 關(guān)注公...
    前端進階之旅閱讀 6,701評論 3 110
  • Ajax 模塊也是經(jīng)常會用到的模塊,Ajax 模塊中包含了 jsonp 的現(xiàn)實,和 XMLHttpRequest ...
    對角另一面閱讀 612評論 0 1
  • 五十三:請解釋 JavaScript 中 this 是如何工作的。1.方法調(diào)用模式當一個函數(shù)被保存為一個對象的屬性...
    Arno_z閱讀 591評論 0 2