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

首頁 > 語言 > JavaScript > 正文

原生JS實(shí)現(xiàn)ajax與ajax的跨域請(qǐng)求實(shí)例

2024-05-06 15:23:55
字體:
供稿:網(wǎng)友

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

第一步獲得XMLHttpRequest對(duì)象

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

第三步:open一個(gè)連接,true是異步請(qǐng)求

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

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

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

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的跨域請(qǐng)求

[跨域請(qǐng)求處理]由于在JS中存在同源策略。當(dāng)請(qǐng)求不同協(xié)議名,不同端口號(hào),不同主機(jī)名下面的文件時(shí),將會(huì)違背同源策略,無法請(qǐng)求成功!需要進(jìn)行跨域處理!

1、后臺(tái)PHP進(jìn)行設(shè)置:

前臺(tái)無需任何設(shè)置,在后臺(tái)被請(qǐng)求的PHP文件中,寫入一條header。

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

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

①擁有src屬性的標(biāo)簽自帶跨域功能!所以可以使用script標(biāo)簽的src屬性請(qǐng)求后臺(tái)數(shù)據(jù)

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

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

所以,后臺(tái)直接返回JSON字符串將不能在script標(biāo)簽中解析

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

后臺(tái)PHP文件中返回:

echo"callBack({$str})";

③前臺(tái)接收到返回的回到函數(shù),將直接在script標(biāo)簽中調(diào)用。因此需要聲明這樣一個(gè)回調(diào)函數(shù),作為請(qǐng)求成功的回調(diào)。

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

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

① 在ajax請(qǐng)求時(shí),設(shè)置dataType為"json"

② 后套返回時(shí),依然需要返回回調(diào)函數(shù)。但是,ajax在發(fā)送請(qǐng)求時(shí)會(huì)默認(rèn)使用get請(qǐng)求將回到函數(shù)名發(fā)給后臺(tái),后臺(tái)可以使用$_GET['callback']取出回調(diào)函數(shù)名:

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

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

success:function(data){}

當(dāng)然后臺(tái)也可以隨便返回一個(gè)回調(diào)函數(shù)名。

echo"callBack({$str})";

前臺(tái)只要請(qǐng)求成功,就會(huì)自動(dòng)調(diào)用這個(gè)函數(shù)。類似于第2條的②③步

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 淮北市| 洱源县| 阜南县| 蓬安县| 尚志市| 彩票| 云浮市| 横峰县| 班玛县| 阿拉善左旗| 泉州市| 巫山县| 宁明县| 海丰县| 湖北省| 琼海市| 车险| 汾阳市| 黎平县| 招远市| 大邑县| 重庆市| 莱西市| 酒泉市| 苏尼特左旗| 潼关县| 沭阳县| 体育| 平定县| 东至县| 乾安县| 饶阳县| 察隅县| 永德县| 昌乐县| 水富县| 水城县| 玉林市| 明星| 玉溪市| 文登市|