首頁  >  文章  >  後端開發  >  Ajax和jsonp使用方法總結

Ajax和jsonp使用方法總結

小云云
小云云原創
2017-12-25 09:44:152354瀏覽

ajax和jsonp可以與後台通信,獲取數據和信息,但是又不用刷新整個頁面,實現頁面的局部刷新。本文將帶領大家學習Ajax和jsonp使用方法,所以我們對Ajax和jsonp使用方法做了一個總結分享給大家,需要的朋友可以參考下,希望能幫助到大家。

一、ajax

•定義:一種發送http請求與後台進行非同步通訊的技術。

•原理:實例化xmlhttp對象,使用此物件與後台通訊。

ajax的同源策略:

•ajax請求的頁面或資源只能是同一個網域下面的資源,不能是其他網域的資源,這是在設計ajax時基於安全考慮。

-------------------------------------------- ------------------------------------

ajax的方法:

1. $.ajax({}):

•常用參數: •url:請求網路位址
•type:請求方式,預設為'GET',常用'POST'
•dataType:設定傳回的資料格式,一般使用json,也可以是html和jsonp;
•data:設定傳送給伺服器的資料
•.done():設定請求成功後的回呼函數
•.fail():設定請求失敗後的回呼函數
•async:設定是否異步,預設值是'true',表示非同步

•程式碼運用:

$(function () {
  $("input").click(function () {
    $.ajax({
      url: "./data.json",
      type: "get",
      dataType: "json",
    });
    .done(function(data) {//请求成功的回调函数
      $("input").val(dat.name);
    })
    .fail(function() {
      alert('服务器超时,请重试!');
    });
  });
})
......
<body>
  <p>
    <input type="button" value="xinzhi">
  </p>
</body>

說明:data表示後台傳回的資料;ajax使用需要依賴伺服器環境。

2. $.get():

•$.get() 方法使用GET請求從伺服器載入資料;也是一種無刷新的請求資料的ajax方法。

•參數:
•url:存取的網址,需要遵循同源策略;
•data:傳送到伺服器的資料。
•function(data,status){}:請求成功運行的函數
•dataType:請求回應的資料類型。

//参考代码:
$(function () {
  $("input").click(function () {
    $.get(
      "./data.json",
      function (data,status) {
        console.log(data.name);
      },
      "json"
    );
  });
})
......
<body>
  <p>
    <input type="button" value="xinzhi">
  </p>
</body>

•$.get()方法的參數和$.ajax()不一樣,網址url為必須的參數,其他三個可選。
•data為傳回的數據,status表示請求的狀態,一般有""success","error","timeout"等幾種。
•如果datatype類型為jsonp,也可以跨域請求數據。其使用的方法和$.get()方法完全一樣。放置到元素中。的回呼函數。 •無請求失敗的回呼函數。網址,必須的參數;
•data: 傳送給伺服器的資料;

•function(data,status,xhr):請求成功的回呼函數

$(function () {
  $("input").click(function () {
    $(".box").load(
      "./data.json",
      function (response,status) {
        console.log(data.name);
      }
    );
  });
})
......
<body>
  <p>
    <input type="button" value="xinzhi">
    <p class="box"></p>
  </p>
</body>
•方法直接取得的是json資料;


•無傳回失敗的回呼函數;

•回呼函數時命名函數,不是匿名函數;

5.getScript()

•方法使用AJAX 的HTTP GET 請求取得並執行js程式碼。 status):請求成功的回呼函數

$(function () {
  $("input").click(function () {
    $.getJSON(
      "./data.json",
      function(data,status) {
        console.log(data.name);
      },
    );
  });
})
......
<body>
  <p>
    <input type="button" value="xinzhi">
  </p>
</body>

•傳回結data是js程式碼;
•此方法可以用來動態載入js程式碼。

##•定義:一種可以實現跨域發送http請求的資料通訊格式,可以嵌在ajax中使用。 ##用法一:函數傳參

$(function () {
  $("input").click(function () {
    $.getScript(
      "./data.js",
      function(data,status) {
        console.log(data);
      },
    );
  });
})
......
<body>
  <p>
    <input type="button" value="xinzhi">
  </p>
</body>

說明:在外部定義一個data.js文件,這個文件的路徑可以與目前頁面不在同一個域下面。內容:
<script type="text/javascript">
  function aa(data){
    console.log(data.name);
  }
</script>
<script type="text/javascript" src="....../data.js"></script>

•將資料以頁面定義的函數的參數的形式傳遞進去,從而取得資料。

•本質上可以將資料拆分,使得資料不用強制保存在同一個網域下。

用法二:利用ajax

aa({
  
  "data":{
    "name":"xiaohong",
    "age":"18"
  }
})

•data.js的內容和上面一樣。

•使用ajax的方法本質上也是script標籤可以跨域連結資源,不過jquery為其封裝了相同的方法,看起來一樣。

•以上程式碼的執行過程為:ajax透過jsonp技術跨域存取data.js文件,透過找到aa()方法將其參數傳遞給.done方法的data參數執行.done方法。

•目前這種方式仍然有其局限性,就是必須知道data.js檔案的名字和定義的方法aa,如果在僅僅知道域名的情況下,需要另外的方法.

用法三

$.ajax({
  url:'...../data.js',//可以不是本地域名 
  type:'get',
  dataType:'jsonp', //jsonp格式访问
  jsonpCallback:'aa' //获取数据的函数
})
.done(function(data){
  console.log(data.name);
})
.fail(function() {
  alert('服务器超时,请重试!');
});

•透過瀏覽器查看每次輸入關鍵字伺服器發送回的資料包,找到js檔案中header的位址以及相關的提交數據,發現key為word關鍵字,因此可以向伺服器發送data資料。

•伺服器傳回的資料會自動傳給回呼的匿名函數的參數data.

相關推薦:

原生JS如何實作AJAX、JSONP

json和jsonp的區別和用法

javascript中ajax和jsonp使用技巧程式碼詳解

以上是Ajax和jsonp使用方法總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn