欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生JS實現(xiàn)ajax與ajax的跨域請求實例

 更新時間:2017年12月01日 10:22:53   作者:君無藥  
下面小編就為大家分享一篇原生JS實現(xiàn)ajax與ajax的跨域請求實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

一、原生JS實現(xiàn)ajax

第一步獲得XMLHttpRequest對象

第二步:設置狀態(tài)監(jiān)聽函數(shù)

第三步:open一個連接,true是異步請求

第四部:send一個請求,可以發(fā)送一個對象和字符串,不需要傳遞數(shù)據(jù)發(fā)送null

第五步:在監(jiān)聽函數(shù)中,判斷readyState=4&&status=200表示請求成功

第六步:使用responseText、responseXML接受響應數(shù)據(jù),并使用原生JS操作DOM進行顯示

var ajax = new XMLHttpRequest();
ajax.onreadystatechange = function(){
 console.log(ajax.readyState);
 console.log(ajax.status);
 if(ajax.readyState==4 && ajax.status==200){
  console.log(ajax.responseText);
  console.log(ajax.responseXML);//返回不是XML,顯示null
  console.log(JSON.parse(ajax.responseText));
  console.log(eval("("+ajax.responseText+")"));
  }
}
ajax.open("GET","h51701.json",true);
ajax.send(null);

二、ajax的跨域請求

[跨域請求處理]由于在JS中存在同源策略。當請求不同協(xié)議名,不同端口號,不同主機名下面的文件時,將會違背同源策略,無法請求成功!需要進行跨域處理!

1、后臺PHP進行設置:

前臺無需任何設置,在后臺被請求的PHP文件中,寫入一條header。

header("Access-Control-Allow-Origin:*");//表示允許哪些域名請求這個PHP文件,*表示所有域名都允許

2、使用src屬性+JSONP實現(xiàn)跨域

①擁有src屬性的標簽自帶跨域功能!所以可以使用script標簽的src屬性請求后臺數(shù)據(jù)

<scriptsrc="http://127.0.0.1/json.php"type="text/javascript"charset="utf-8"></script>

②由于src在加載數(shù)據(jù)成功后,后直接將加載內容放入到script標簽中

所以,后臺直接返回JSON字符串將不能在script標簽中解析

因此,后臺應該返回給前臺一個回到函數(shù)名,并將JSON字符串作為參數(shù)傳入

后臺PHP文件中返回:

echo"callBack({$str})";

③前臺接收到返回的回到函數(shù),將直接在script標簽中調用。因此需要聲明這樣一個回調函數(shù),作為請求成功的回調。

function callBack(data){
  alert("請求成功");
  console.log(data);
 }

3、JQuery的ajax實現(xiàn)JSONP

① 在ajax請求時,設置dataType為"json"

② 后套返回時,依然需要返回回調函數(shù)。但是,ajax在發(fā)送請求時會默認使用get請求將回到函數(shù)名發(fā)給后臺,后臺可以使用$_GET['callback']取出回調函數(shù)名:

echo"{$_GET['callback']}({$str})";

③后臺返回以后,ajax依然可以用success作為成功的回調函數(shù):

success:function(data){}

當然后臺也可以隨便返回一個回調函數(shù)名。

echo"callBack({$str})";

前臺只要請求成功,就會自動調用這個函數(shù)。類似于第2條的②③步

以上這篇原生JS實現(xiàn)ajax與ajax的跨域請求實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Javascript 數(shù)組添加 shuffle 方法的實現(xiàn)代碼

    Javascript 數(shù)組添加 shuffle 方法的實現(xiàn)代碼

    PHP 里面有個非常方便的打亂數(shù)組的函數(shù) shuffle() ,這個功能在許多情況下都會用到,但 javascript 的數(shù)組卻沒有這個方法,沒有不要緊,可以擴展一個,自己動手,豐衣足食嘛。
    2009-09-09
  • Uploadify上傳文件方法

    Uploadify上傳文件方法

    Uploadify是JQuery的一個上傳插件,實現(xiàn)的效果非常不錯,帶進度顯示。接下來通過本文給大家介紹Uploadify上傳文件方法,涉及到Uploadify在Aspnet中的使用相關知識,本文介紹的非常詳細,具有參考借鑒價值,需要的朋友一起學習吧
    2016-03-03
  • Javascript中內建函數(shù)reduce的應用詳解

    Javascript中內建函數(shù)reduce的應用詳解

    內建函數(shù)其實就是內置函數(shù),reduce函數(shù)是ECMAScript5規(guī)范中出現(xiàn)的數(shù)組方法。在平時的工作中,相信大家使用的場景并不多,這篇文章給大家詳細介紹了函數(shù)reduce的應用以及多重疊加,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • 構建一個JavaScript插件系統(tǒng)

    構建一個JavaScript插件系統(tǒng)

    這篇文章主要介紹了如何構建一個JavaScript插件系統(tǒng),幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下
    2020-10-10
  • 純js分頁代碼(簡潔實用)

    純js分頁代碼(簡潔實用)

    純js寫的分頁代碼且簡潔實用哦!需要的朋友可以過來參考下,希望對大家有所幫助
    2013-11-11
  • Javascript 獲取鼠標當前的位置實現(xiàn)方法

    Javascript 獲取鼠標當前的位置實現(xiàn)方法

    這篇文章主要介紹了Javascript 獲取鼠標當前的位置實現(xiàn)方法的相關資料,需要的朋友可以參考下
    2016-10-10
  • javascript中select下拉框的用法總結

    javascript中select下拉框的用法總結

    這篇文章主要為大家介紹了javascript中select下拉框的用法,select在開發(fā)中經(jīng)常被用到,用于進行選項選擇,需要的朋友可以參考下
    2016-01-01
  • Js實現(xiàn)雙擊鼠標自動滾動屏幕的示例代碼

    Js實現(xiàn)雙擊鼠標自動滾動屏幕的示例代碼

    這篇文章主要介紹了Js實現(xiàn)雙擊鼠標自動滾動屏幕的示例代碼。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • JS控件bootstrap suggest plugin使用方法詳解

    JS控件bootstrap suggest plugin使用方法詳解

    這篇文章主要介紹了JS控件bootstrap suggest plugin的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • 瀏覽器窗口加載和大小改變事件示例

    瀏覽器窗口加載和大小改變事件示例

    這篇文章主要介紹了瀏覽器窗口加載和大小改變事件,需要的朋友可以參考下
    2014-02-02

最新評論