国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

原生JS實現ajax與ajax的跨域請求實例

2019-11-19 14:48:44
字體:
來源:轉載
供稿:網友

一、原生JS實現ajax

第一步獲得XMLHttpRequest對象

第二步:設置狀態監聽函數

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

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

第五步:在監聽函數中,判斷readyState=4&&status=200表示請求成功

第六步:使用responseText、responseXML接受響應數據,并使用原生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中存在同源策略。當請求不同協議名,不同端口號,不同主機名下面的文件時,將會違背同源策略,無法請求成功!需要進行跨域處理!

1、后臺PHP進行設置:

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

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

2、使用src屬性+JSONP實現跨域

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

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

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

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

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

后臺PHP文件中返回:

echo"callBack({$str})";

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

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

3、JQuery的ajax實現JSONP

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

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

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

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

success:function(data){}

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

echo"callBack({$str})";

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 长子县| 含山县| 始兴县| 商丘市| 丹巴县| 远安县| 汤原县| 区。| 丰顺县| 互助| 萝北县| 潢川县| 遂昌县| 涟水县| 长子县| 黔西县| 塘沽区| 武隆县| 信阳市| 永宁县| 伊春市| 广南县| 图们市| 舟山市| 洛扎县| 呼伦贝尔市| 南溪县| 深州市| 泾源县| 北碚区| 梁河县| 惠来县| 沛县| 江源县| 大庆市| 唐海县| 深圳市| 长春市| 平武县| 英超| 四平市|