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 () { $("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()
$(function () { $("input").click(function () { $.getJSON( "./data.json", function(data,status) { console.log(data.name); }, ); }); }) ...... <body> <p> <input type="button" value="xinzhi"> </p> </body>
##•定義:一種可以實現跨域發送http請求的資料通訊格式,可以嵌在ajax中使用。 ##用法一:函數傳參
$(function () { $("input").click(function () { $.getScript( "./data.js", function(data,status) { console.log(data); }, ); }); }) ...... <body> <p> <input type="button" value="xinzhi"> </p> </body>
<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" } })
•使用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.相關推薦:
javascript中ajax和jsonp使用技巧程式碼詳解
以上是Ajax和jsonp使用方法總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!