原生JS實(shí)現(xiàn)ajax與ajax的跨域請(qǐng)求實(shí)例
一、原生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條的②③步
以上這篇原生JS實(shí)現(xiàn)ajax與ajax的跨域請(qǐng)求實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 詳解Django解決ajax跨域訪問問題
- Ajax實(shí)現(xiàn)跨域訪問最新解決方案
- 簡(jiǎn)單實(shí)現(xiàn)ajax獲取跨域數(shù)據(jù)
- SpringBoot解決ajax跨域問題的方法
- 淺談Koa2框架利用CORS完成跨域ajax請(qǐng)求
- ajax前臺(tái)后臺(tái)跨域請(qǐng)求處理方式
- vue-cli開發(fā)時(shí),關(guān)于ajax跨域的解決方法(推薦)
- ajax跨域獲取網(wǎng)站json數(shù)據(jù)的實(shí)例
- 淺談jquery中ajax跨域提交的時(shí)候會(huì)有2次請(qǐng)求的問題
- JQuery Ajax執(zhí)行跨域請(qǐng)求數(shù)據(jù)的解決方案
相關(guān)文章
Javascript 數(shù)組添加 shuffle 方法的實(shí)現(xiàn)代碼
PHP 里面有個(gè)非常方便的打亂數(shù)組的函數(shù) shuffle() ,這個(gè)功能在許多情況下都會(huì)用到,但 javascript 的數(shù)組卻沒有這個(gè)方法,沒有不要緊,可以擴(kuò)展一個(gè),自己動(dòng)手,豐衣足食嘛。2009-09-09Javascript中內(nèi)建函數(shù)reduce的應(yīng)用詳解
內(nèi)建函數(shù)其實(shí)就是內(nèi)置函數(shù),reduce函數(shù)是ECMAScript5規(guī)范中出現(xiàn)的數(shù)組方法。在平時(shí)的工作中,相信大家使用的場(chǎng)景并不多,這篇文章給大家詳細(xì)介紹了函數(shù)reduce的應(yīng)用以及多重疊加,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-10-10構(gòu)建一個(gè)JavaScript插件系統(tǒng)
這篇文章主要介紹了如何構(gòu)建一個(gè)JavaScript插件系統(tǒng),幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下2020-10-10Javascript 獲取鼠標(biāo)當(dāng)前的位置實(shí)現(xiàn)方法
這篇文章主要介紹了Javascript 獲取鼠標(biāo)當(dāng)前的位置實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2016-10-10javascript中select下拉框的用法總結(jié)
這篇文章主要為大家介紹了javascript中select下拉框的用法,select在開發(fā)中經(jīng)常被用到,用于進(jìn)行選項(xiàng)選擇,需要的朋友可以參考下2016-01-01Js實(shí)現(xiàn)雙擊鼠標(biāo)自動(dòng)滾動(dòng)屏幕的示例代碼
這篇文章主要介紹了Js實(shí)現(xiàn)雙擊鼠標(biāo)自動(dòng)滾動(dòng)屏幕的示例代碼。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12JS控件bootstrap suggest plugin使用方法詳解
這篇文章主要介紹了JS控件bootstrap suggest plugin的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03