這次帶給大家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('服务器超时,请重试!'); }); }); }) ...... <p> <input> </p>
說明: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" ); }); }) ...... <p> <input> </p>
•$.get()方法的參數和$.ajax()不一樣,網址url為必須的參數,其他三個可選。
•data為傳回的數據,status表示請求的狀態,一般有""success","error","timeout"等幾種。
•如果datatype類型為jsonp,也可以跨域請求數據。資料;
•其使用的方法和$.get()方法完全一樣。數據,不需要指定datatype,傳回的資料會自動放置到元素中。 •function(response,status,xhr):請求成功的回呼函數。的數據,status為請求的狀態;
$(function () { $("input").click(function () { $(".box").load( "./data.json", function (response,status) { console.log(data.name); } ); }); }) ...... <p> <input> </p><p></p>•方法直接取得的是json資料;#•無回傳失敗的回呼函數;
##•回呼函數時命名函數,不是匿名函數;
5.getScript()
•方法使用AJAX 的HTTP GET 請求取得並執行js程式碼。•url: 請求網址,必須的參數;
$(function () { $("input").click(function () { $.getJSON( "./data.json", function(data,status) { console.log(data.name); }, ); }); }) ...... <p> <input> </p>
•傳回結data是js程式碼;
•此方法可以用來動態載入js程式碼。
•定义:一种可以实现跨域发送http请求的数据通信格式,可以嵌在ajax中使用。
•原理:利用script标签可以跨域链接资源的特性。
用法一:函数传参
<script> function aa(data){ console.log(data.name); } </script> <script></script>
说明:在外部定义一个data.js文件,这个文件的路径可以与当前页面不在同一个域下面。
data.js的内容:
aa({ "data":{ "name":"xiaohong", "age":"18" } })
•将数据以页面定义的函数的参数的形式传递进去,从而获取数据。
•本质上可以将数据拆分,使得数据不用强制保存在同一个域名下。
用法二:利用ajax
$.ajax({ url:'...../data.js',//可以不是本地域名 type:'get', dataType:'jsonp', //jsonp格式访问 jsonpCallback:'aa' //获取数据的函数 }) .done(function(data){ console.log(data.name); }) .fail(function() { alert('服务器超时,请重试!'); });
•data.js的内容和上面一样。
•使用ajax的方法本质上也是script标签可以跨域链接资源,不过jquery为其封装了相同的方法,看起来一样。
•以上代码的执行过程为:ajax通过jsonp技术跨域访问data.js文件,通过找到aa()方法将其参数传递给.done方法的data参数执行.done方法。
•目前这种方式仍然有其局限性,就是必须知道data.js文件的名字和定义的方法aa,如果在仅仅知道域名的情况下,需要另外的方法.
用法三
var $input = $("input"); $input.keyup(function () { $.ajax({ url:'https://sug.so.360.cn/suggest?',//请求360搜索的联想数据 type:'get', dataType:'jsonp', //jsonp格式访问 data: {word: $input.val()}, }) .done(function(data){ console.log(data); }) .fail(function() { alert('服务器超时,请重试!'); }); }) .... <input>
•通过浏览器查看每次输入关键字服务器发送回的数据包,找到js文件中header的地址以及相关的提交数据,发现key为word关键字,因此可以向服务器发送data数据。
•服务器返回的数据会自动传给回调的匿名函数的参数data.
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上是Ajax和jsonp在專案中的實戰總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

Python和JavaScript的未來趨勢包括:1.Python將鞏固在科學計算和AI領域的地位,2.JavaScript將推動Web技術發展,3.跨平台開發將成為熱門,4.性能優化將是重點。兩者都將繼續在各自領域擴展應用場景,並在性能上有更多突破。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

是的,JavaScript的引擎核心是用C語言編寫的。 1)C語言提供了高效性能和底層控制,適合JavaScript引擎的開發。 2)以V8引擎為例,其核心用C 編寫,結合了C的效率和麵向對象特性。 3)JavaScript引擎的工作原理包括解析、編譯和執行,C語言在這些過程中發揮關鍵作用。

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器