婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)

AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)

熱門標(biāo)簽:中國地圖標(biāo)注不明確情況介紹表 立陶宛地圖標(biāo)注 上海企業(yè)外呼系統(tǒng)價(jià)錢 電銷機(jī)器人 長春 大眾點(diǎn)評(píng)400電話怎么申請(qǐng) 東平縣地圖標(biāo)注app 怎樣在地圖標(biāo)注文字 河間市地圖標(biāo)注app 地圖標(biāo)注推銷坑人

由于瀏覽器的同源策略 ajax請(qǐng)求不可以接收到請(qǐng)求響應(yīng)回來的數(shù)據(jù) 

請(qǐng)求數(shù)據(jù)需要調(diào)用瀏覽器的內(nèi)置構(gòu)造函數(shù) XMLHttpRequest() 進(jìn)行 實(shí)例對(duì)象

var xhr = new XMLHttpRequest();

注意點(diǎn) 在IE8之前支持的 ActiveXobject("Microsoft.XMLHTTP");  記住要進(jìn)行兼容處理哦  在這里我就不寫了

通過該對(duì)象進(jìn)行獲取

獲取數(shù)據(jù)的四種狀態(tài)  xhr.readyState 該屬性保存著請(qǐng)求數(shù)據(jù)的幾種狀態(tài)

1.xhr.open(請(qǐng)求方式,請(qǐng)求地址,設(shè)置同/異步);

2.xhr.send(null);//發(fā)送請(qǐng)求  如果是post請(qǐng)求 那么參數(shù)需要在send中進(jìn)行傳遞

3.會(huì)一直檢測數(shù)據(jù)是否返回

4.數(shù)據(jù)返回 那么xhr.readyState的值是4  說明數(shù)據(jù)返回成功

那么我們需要進(jìn)行跨域請(qǐng)求如何做呢

方案一:

利用script標(biāo)簽的src屬性請(qǐng)求數(shù)據(jù)  src屬性請(qǐng)求的數(shù)據(jù)瀏覽器是不會(huì)進(jìn)行攔截的

script srrc="http://jiang.com/AJAX/data.php">script/>

這樣我們是可以請(qǐng)求到數(shù)據(jù)的  但是這樣有一些缺點(diǎn)

1.我們無法控制何時(shí)發(fā)送請(qǐng)求的  頁面加載到這里就是發(fā)送請(qǐng)求的

2.這樣的方式  請(qǐng)求方式是同步的請(qǐng)求 需要請(qǐng)求到數(shù)據(jù)才會(huì)執(zhí)行下一步的代碼  這樣頁面加載時(shí)間可能延長

3.所以建議不要使用這樣的方式 不推薦

方案二:

在js中動(dòng)態(tài)創(chuàng)建script標(biāo)簽 指定請(qǐng)求的接口

var script = document.createELement("script");

//將script追加到head標(biāo)簽中

document.getElementsTagName("head")[0].appendChild(script);

優(yōu)點(diǎn):我們可以控制請(qǐng)求的時(shí)機(jī)  并且這樣請(qǐng)求的方式是異步的 不會(huì)延長頁面加載的時(shí)間

重要點(diǎn):我們可以在請(qǐng)求數(shù)據(jù)中調(diào)用請(qǐng)求頁面中的函數(shù)  使用函數(shù)的形參接收請(qǐng)求回來的數(shù)據(jù)

方案三:

在請(qǐng)求的后端接口設(shè)置一個(gè) 請(qǐng)求頭即可

Access-Control-Allow-Origin

含有這個(gè)請(qǐng)求頭 前端頁面跨域請(qǐng)求的數(shù)據(jù)就不會(huì)被瀏覽器進(jìn)行攔截啦

方案四:

使用iframe>標(biāo)簽 將一個(gè)頁面 將可以可變的內(nèi)容部分放置在該標(biāo)簽中  發(fā)送請(qǐng)求就會(huì)進(jìn)行刷新啦  嚴(yán)格意義上不算ajax啦 

該方式在ajax未出現(xiàn)  就是使用該標(biāo)簽實(shí)現(xiàn)請(qǐng)求數(shù)據(jù)的

以上這篇AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 詳解自定義ajax支持跨域組件封裝
  • vue-cli開發(fā)時(shí),關(guān)于ajax跨域的解決方法(推薦)
  • ajax跨域獲取網(wǎng)站json數(shù)據(jù)的實(shí)例
  • 原生JS實(shí)現(xiàn)ajax與ajax的跨域請(qǐng)求實(shí)例
  • 淺談jquery中ajax跨域提交的時(shí)候會(huì)有2次請(qǐng)求的問題
  • 原生JS實(shí)現(xiàn)Ajax跨域請(qǐng)求flask響應(yīng)內(nèi)容
  • Springmvc ajax跨域請(qǐng)求處理方法實(shí)例詳解
  • 原生js的ajax和解決跨域的jsonp(實(shí)例講解)
  • 基于CORS實(shí)現(xiàn)WebApi Ajax 跨域請(qǐng)求解決方法
  • Ajax如何進(jìn)行跨域請(qǐng)求?Ajax跨域請(qǐng)求的原理
  • 詳解ajax跨域問題解決方案
  • ajax前臺(tái)后臺(tái)跨域請(qǐng)求處理方式

標(biāo)簽:本溪 玉樹 營口 遼寧 四川 益陽 銅川 內(nèi)江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)》,本文關(guān)鍵詞  AJAX,跨域,請(qǐng)求,數(shù)據(jù),的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)》相關(guān)的同類信息!
  • 本頁收集關(guān)于AJAX跨域請(qǐng)求數(shù)據(jù)的四種方法(實(shí)例講解)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 大洼县| 株洲市| 车险| 临高县| 依兰县| 峨边| 黑河市| 榆社县| 新野县| 九龙坡区| 佳木斯市| 晋州市| 开江县| 顺昌县| 宁武县| 酉阳| 武宁县| 雅安市| 万源市| 格尔木市| 枣庄市| 湟中县| 卢龙县| 九龙县| 天峻县| 衡山县| 项城市| 上栗县| 防城港市| 台东市| 噶尔县| 松桃| 高尔夫| 泰顺县| 望都县| 五寨县| 会同县| 石台县| 东兰县| 福清市| 荣成市|