跨域問(wèn)題匯總

由例子引入:
先列下html結(jié)構(gòu)

<body>
  <div id="mydiv">
    <button id="btn">點(diǎn)擊</button>
  </div>
</body>

一、異步請(qǐng)求ajax(因?yàn)g覽器同源策略不能跨域)

<script type="text/javascript">
  window.onload=function(){
    var btn=document.getElementById("btn");
    btn.onclick=function(){
      var xhr=new XMLHttpRequest();//創(chuàng)建一個(gè)XMLHttpRequest對(duì)象
      xhr.onreadystatechange=function(){//readyState每變化一次,就執(zhí)行一次這個(gè)事件
        if(xhr.readyState==4 && xhr.status=200){//請(qǐng)求已完成,響應(yīng)已就緒
          alert(xhr.responseText);
        }
      };
      xhr.open("get","https://api.douban.com/v2/book/search?q=javascript&count=1",true);
      xhr.send();
    }
  }

二、JSONP(JSON with Padding 填充式JSON或參數(shù)式JSON)==》解決不能跨域的問(wèn)題的方法之一
原理:動(dòng)態(tài)創(chuàng)建<script>標(biāo)簽,利用<script>的src不受同源策略約束來(lái)跨域獲取數(shù)據(jù)。
在body后加<script>

<script type="text/javascript">
  function handleResponse(response){
    console.log(response);
  }
</script>
<script type="text/javascript">
  window.onload=function(){
    var btn=document.getElementById("btn");
    btn.onclick=function(){
      var script=document.createElement("script");
      script.src="https://api.douban.com/v2/book/search?q=javascript&count=1&callback=handleResponse";
      document.body.insertBefore(script,document.body.firstChild);  
    };
  };
</script>

三、跨域在jQuery中的實(shí)現(xiàn)

$(document).ready(function(){//或簡(jiǎn)寫$(function(){})
  $("#btn").click(function(){
    $.ajax({
      async:true,
      url:"https://api.douban.com/v2/book/search",
      type:"GET",
      dataType:"jsonp",
      jsonp:"callback",
      jsonpCallback:"handleResponse",
      data:{
        q:"javascript",
        count:1,
      },
      success:function(response,status,xhr){
        console.log("狀態(tài)為:"+status+"狀態(tài)是:"+xhr.statusText);
        console.log(response);
      }
    });
  });
});

實(shí)現(xiàn)結(jié)果:


結(jié)果.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容