首頁 > web前端 > js教程 > 主體

js跨域請求資料的3種常用的方法_javascript技巧

WBOY
發布: 2016-05-16 15:28:32
原創
1538 人瀏覽過

由於js同源策略的影響,當在某一域名下請求其他域名,或者同一域名,不同端口下的url時,就會變成不被允許的跨域請求。
那這個時候通常怎麼解決呢,對此菜鳥光頭我稍作了整理:
1.JavaScript
在原生js(沒有jQuery和ajax支援)的情況下,通常客戶端程式碼是這樣的(我假設是在localhost:8080的連接埠下的http://localhost:8080/webs/i.mediapower.mobi/wutao /index.html頁面的body標籤下方加入以下程式碼):

<script>
  var xhr = new XMLHttpRequest();
  xhr.open("get", "http://i2.mediapower.mobi/adpower/vm/Bora/js/test.js", true);
  xhr.onreadystatechange = function() {
    if (xhr.readyState == 4 && xhr.status == 200) {
      console.log(xhr.responseText);
    }
  };
  xhr.send(null);
</script>
登入後複製

儲存,瀏覽器開啟http://localhost:8080/webs/i.mediapower.mobi/wutao/index.html,並且開啟console控制台:


瀏覽器很無情的給你彈出一個同源限制的錯誤,意思就是你無法跨域請求url的資料。
那麼,我先採取第一種策略,運用html中的script標籤,插入js腳本:
(1)透過script標籤引用,寫死你需要的src的url位址,例如:

<script>
var callbackfunction = function(data) {
  console.log('我是跨域请求来的数据-->' + data.name);
};
</script>
<script src="http://i2.mediapower.mobi/adpower/vm/Bora/js/test.js&#63;callback=callbackfunction"></script> 
登入後複製

這裡我定義一個callbackfunction的函數,然後用script標籤的src屬性跨域請求數據,那麼,test.js的內容經過約定,需要寫成這樣:
callbackfunction({"name":"wwwwwwwwwwww"});
儲存,開啟index.html並重新整理:


(2)你也可以動態的加入script標籤,讓html解析的時候,動態的載入script腳本,並要求遠端資料:

<script>
var callbackfunction = function(data) {
  console.log('我是跨域请求来的数据-->' + data.name);
};
var script = document.createElement('script'),
  body = document.getElementsByTagName('body');

script.src = 'http://i2.mediapower.mobi/adpower/vm/Bora/js/test.js&#63;callback=callbackfunction';
body[0].appendChild(script);
</script>

登入後複製

結果和上面一樣。

 

2.jQuery中的$.ajax()

   設想,當你想要使用jQuery請求跨域資料的時候,例如(還是剛才的index.html):

<script src="js/jquery-1.11.3.js"></script>
<script>
$(function(){
  $.get('http://i2.mediapower.mobi/adpower/vm/Bora/js/test.js',function(data){
    console.log(data);
  })
})
</script>
登入後複製

瀏覽器還是無情的報錯,因為你這個url是不同的網域下的。

那麼既然jQuery封裝了ajax方法,我們為何不用,人家封裝好了,你不用,豈不是找罪受麼,代碼如下:

<script src="js/jquery-1.11.3.js"></script>
<script>
$(function(){
  $.ajax({
    async: false,
    type: "GET",
    dataType: 'jsonp',
    jsonp: 'callback',
    jsonpCallback: 'callbackfunction',
    url: "http://i2.mediapower.mobi/adpower/vm/Bora/js/test.js",
    data: "",
    timeout: 3000,
    contentType: "application/json;utf-8",
    success: function(msg) {
      console.log(msg);
    }
  });
})
</script>
登入後複製

當你作了這麼多挑逗工作之後,瀏覽器很爽快的給出了反應,表示它很爽,返回給了你一個對象,裡面是遠端不同域名下test.js中的數據。
3.postMessage iframe

   postMessage是HTML5中新增加的功能,例如我在本地網域下,http://192.168.1.152:8080/webs/i.mediapower.mobi/wutao/testa.html中的testa.html中:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>testa</title>
</head>
<script>
window.onload = function() {
  document.getElementById('ifr').contentWindow.postMessage('我是要经过传递的数据', 'http://i2.mediapower.mobi/adpower/vm/Bora/testb.html');
};
</script>
<body>
  <iframe id="ifr" src="http://i2.mediapower.mobi/adpower/vm/Bora/testb.html"></iframe>
</body>
</html>
登入後複製

此時,我遠端的testb.html裡面的內容應該是這樣:

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <title>testb</title>
</head>
<script>
window.addEventListener('message', function(event) {
  // 通过origin属性判断消息来源地址
  if (event.origin === 'http://192.168.1.152:8080') {
    alert(event.data); 
  }
}, false);
</script>
<body>
123
</body>
</html>

登入後複製

儲存程式碼,開啟本機testa.html,存取遠端的testb.html


總結了一下,jQuery還是非常的好用的,基本上js能幹的事情,jQuery都能非常快速並且高效的完成,當然,原生js也能解決很多事情,而HTML5的新功能也非常強大,這幾種方法,我還是首推jQuery。

以上就是為大家分享的3種常用的js跨域請求資料的方法,希望對大家的學習有所幫助。

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板