ajax和跨域的一些問題

簡單的總結(jié)下ajax和跨域問題。

手寫原生ajax算是比較高頻的面試題了塔鳍,目的就是看你是否明白其原理伯铣。
首先是XMLHttpRequest對象,現(xiàn)代瀏覽器均支持(IE5 和 IE6 使用 ActiveXObject)轮纫。它是一個window對象腔寡。它的reponseText屬性可以獲取返回數(shù)據(jù)。readyState和status屬性可以標(biāo)識返回狀態(tài)掌唾。
onreadystatechange是一個事件放前,或者說一個函數(shù)。

var request = new XMLHttpRequset();
request.onreadystatechange = function () {
    if (request.readyState ==4 && request.status == 200) {
            alert(requset.reponseText)//成功糯彬,返回reponseText
            }else {
            alert(requset.status)  //失敗凭语,返回錯誤狀態(tài)碼
            }
        }
requset.get('GET', url, true) ;//默認(rèn)為true,可不寫撩扒。表示異步
requset.send()
  1. jsonp跨域似扔。
    原理:利用script標(biāo)簽可跨域的特性。
<button onclick="getPrice()">點擊刷新</button>
<p id="test"></p>
function refreshPrice(data) {
            var p = document.getElementById('test');
            p.innerHTML = '當(dāng)前價格:' +
            data['0000001'].name +': ' + 
            data['0000001'].price + '搓谆;' +
            data['1399001'].name + ': ' +
            data['1399001'].price;
        }
        
function getPrice() {
            var script = document.createElement('script');
            var head = document.getElementsByTagName('head')[0];
            script.src = 'http://api.money.126.net/data/feed/0000001,1399001?callback=refreshPrice';
            head.appendChild(script)
        }

借用了廖雪峰老師網(wǎng)站里的例子炒辉。

  1. CORS。
    CORS全稱Cross-Origin Resource Sharing泉手,是HTML5規(guī)范定義的如何跨域訪問資源黔寇。設(shè)置服務(wù)端Access-Control-Allow-Origin
  2. 服務(wù)器代理。同源域名下設(shè)置一個代理服務(wù)器來轉(zhuǎn)發(fā)斩萌。
  3. window.name
  4. document.domain
  5. window.postMessage
    下面3個網(wǎng)上都有許多介紹缝裤。我反正是不怎么了解屏轰。。倘是。額亭枷。。

這個是借鑒網(wǎng)上一篇博客的總結(jié)搀崭,總之具體問題具體對待吧叨粘。

  1. jsonp 需要目標(biāo)服務(wù)器配合一個callback函數(shù)。
  2. window.name+iframe 需要目標(biāo)服務(wù)器響應(yīng)window.name瘤睹。
  3. window.location.hash+iframe 同樣需要目標(biāo)服務(wù)器作處理升敲。
  4. html5的 postMessage+ifrme 這個也是需要目標(biāo)服務(wù)器或者說是目標(biāo)頁面寫一個postMessage,主要側(cè)重于前端通訊轰传。
  5. CORS 需要服務(wù)器設(shè)置header :Access-Control-Allow-Origin
  6. nginx反向代理
    這個方法一般很少有人提及驴党,但是他可以不用目標(biāo)服務(wù)器配合,不過需要你搭建一個中轉(zhuǎn)nginx服務(wù)器获茬,用于轉(zhuǎn)發(fā)請求港庄。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市恕曲,隨后出現(xiàn)的幾起案子鹏氧,更是在濱河造成了極大的恐慌,老刑警劉巖佩谣,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件把还,死亡現(xiàn)場離奇詭異,居然都是意外死亡茸俭,警方通過查閱死者的電腦和手機(jī)吊履,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來调鬓,“玉大人艇炎,你說我怎么就攤上這事⌒溆” “怎么了冕臭?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長燕锥。 經(jīng)常有香客問我辜贵,道長,這世上最難降的妖魔是什么归形? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任托慨,我火速辦了婚禮,結(jié)果婚禮上暇榴,老公的妹妹穿的比我還像新娘厚棵。我一直安慰自己蕉世,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布婆硬。 她就那樣靜靜地躺著狠轻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪彬犯。 梳的紋絲不亂的頭發(fā)上向楼,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天,我揣著相機(jī)與錄音谐区,去河邊找鬼湖蜕。 笑死,一個胖子當(dāng)著我的面吹牛宋列,可吹牛的內(nèi)容都是我干的昭抒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼炼杖,長吁一口氣:“原來是場噩夢啊……” “哼灭返!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起坤邪,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤婆殿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后罩扇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡怕磨,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年喂饥,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肠鲫。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡员帮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出导饲,到底是詐尸還是另有隱情捞高,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布渣锦,位于F島的核電站硝岗,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏袋毙。R本人自食惡果不足惜型檀,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望听盖。 院中可真熱鬧胀溺,春花似錦裂七、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至无埃,卻和暖如春徙瓶,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背录语。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工倍啥, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人澎埠。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓虽缕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蒲稳。 傳聞我的和親對象是個殘疾皇子氮趋,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,802評論 2 345