通過實(shí)例解析jQ Ajax操作相關(guān)原理
什么是AJAX
AJAX = 異步的javascript和XML(Asynchronous Javascript and XML)
它不是一門編程語言,而是利用JavaScript在保證頁面不被刷新、頁面鏈接不改變的情況下與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁的技術(shù)。
對于傳統(tǒng)的網(wǎng)頁,如果想更新內(nèi)容,那么必須要刷新整個(gè)頁面,但有了Ajax,便可以在頁面不被全部刷新的情況下更新其內(nèi)容。在這個(gè)過程中,頁面實(shí)際上是在后臺(tái)與服務(wù)器進(jìn)行了數(shù)據(jù)交互,獲得數(shù)據(jù)之后,再利用JavaScript改變頁面,這樣頁面內(nèi)容就會(huì)更新了。(微博頁面加載過程的例子,加載一會(huì) 下方才會(huì)出現(xiàn)內(nèi)容,這其實(shí)就是Ajax加載的過程。)
簡言之,在不重載整個(gè)網(wǎng)頁的情況下,AJAX通過后臺(tái)加載數(shù)據(jù),并在網(wǎng)頁上進(jìn)行顯示。
通過 jQuery AJAX 方法,您能夠使用 HTTP Get 和 HTTP Post 從遠(yuǎn)程服務(wù)器上請求文本、HTML、XML 或 JSON - 同時(shí)您能夠把這些外部數(shù)據(jù)直接載入網(wǎng)頁的被選元素中。
1.jQuery的load()方法
jQuery load()方法是簡單但強(qiáng)大的AJAX方法。
load()方法從服務(wù)器加載數(shù)據(jù),并把返回的數(shù)據(jù)放入被選元素中。
語法:
$("selector").load(url,data,callback);
必須的url參數(shù)規(guī)定記載的url地址
可選的data參數(shù)規(guī)定與請求一同發(fā)送的查詢字符串鍵/值對的集合
可選的callback參數(shù)是load()方法完成后所執(zhí)行的函數(shù)名稱
1、 $('#btn').click(function(){ //只傳一個(gè)url,表示在id為#new-projects的元素里加載index.html $('#new-projects').load('./index.html'); }) 2、 $('#btn').click(function(){ //只傳一個(gè)url,導(dǎo)入的index.html文件含有多個(gè)傳遞參數(shù),類似于:index/html?name='張三' $('#new-projects').load('./index.html',{"name":'張三',"age":12}); }) 3、 //加載文件之后,會(huì)有個(gè)回調(diào)函數(shù),表示加載成功的函數(shù) $('#new-projects').load('./index.html',{"name":'張三',"age":12},function(){ }); 注意:load函數(shù)最好在服務(wù)器網(wǎng)頁中應(yīng)用,也就是說要在服務(wù)器上運(yùn)行,本地調(diào)試需要搭建后端本地環(huán)境。
2. jquery的getJSON方法
jQuery的AJAX中使用getJSON()方法異步加載JSON格式數(shù)據(jù)。獲取服務(wù)器中的數(shù)據(jù),并對數(shù)據(jù)進(jìn)行解析,顯示到頁面中
語法: $.getJSON(url,[data],[callback]) url參數(shù)為請求加載json格式文件的服務(wù)器地址,可選項(xiàng)data參數(shù)為請求時(shí)發(fā)送的數(shù)據(jù),callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù) $.getJSON("./data/getJSON.json", function (data) { var str = "";//初始化保存內(nèi)容變量 $.each(data, function(index,ele) { $('ul').append("<li>"+ele.name+"</li>") }); })
3.jquery的$.get()方法
$.get() 方法通過 HTTP GET 請求從服務(wù)器上請求數(shù)據(jù)
語法:$.get(URL,callback); url參數(shù)規(guī)定你請求的路徑,是必需參數(shù),callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù) $.get('./data/getJSON.json',function(data,status){ console.log(status); //success 200狀態(tài)碼 ok的意思 })
4.jquery的post()方法
與get()方法相比,post()方法多用于以POST方式向服務(wù)器發(fā)送數(shù)據(jù),服務(wù)器接收到數(shù)據(jù)之后,進(jìn)行處理,并將處理結(jié)果返回頁面#
語法:$.post(URL,data,callback); url參數(shù)規(guī)定你請求的路徑,是必需參數(shù),可選的data參數(shù)是連同請求發(fā)送的數(shù)據(jù)??蛇x的callback參數(shù)為數(shù)據(jù)請求成功后執(zhí)行的函數(shù) $.post('/index',{name:'張三'},function(data,status){ console.log(status); })
5. jquery的$.ajax()方法
是做ajax技術(shù)經(jīng)常使用的一個(gè)方法。 總結(jié)21幾個(gè)經(jīng)常使用的參數(shù)
參數(shù)如下:
1.url:
要求為String類型的參數(shù),(默認(rèn)為當(dāng)前頁地址)發(fā)送請求的地址。
2.type:
要求為String類型的參數(shù),請求方式(post或get)默認(rèn)為get。注意其他http請求方法,例如put和delete也可以使用,但僅部分瀏覽器支持。
3.timeout:
要求為Number類型的參數(shù),設(shè)置請求超時(shí)時(shí)間(毫秒)。此設(shè)置將覆蓋$.ajaxSetup()方法的全局設(shè)置。
4.async:
要求為Boolean類型的參數(shù),默認(rèn)設(shè)置為true,所有請求均為異步請求。如果需要發(fā)送同步請求,請將此選項(xiàng)設(shè)置為false。注意,同步請求將鎖住瀏覽器,用戶其他操作必須等待請求完成才可以執(zhí)行。
5.cache:
要求為Boolean類型的參數(shù),默認(rèn)為true(當(dāng)dataType為script時(shí),默認(rèn)為false),設(shè)置為false將不會(huì)從瀏覽器緩存中加載請求信息。
6.data:
要求為Object或String類型的參數(shù),發(fā)送到服務(wù)器的數(shù)據(jù)。如果已經(jīng)不是字符串,將自動(dòng)轉(zhuǎn)換為字符串格式。get請求中將附加在url后。防止這種自動(dòng)轉(zhuǎn)換,可以查看 processData選項(xiàng)。對象必須為key/value格式,例如{foo1:"bar1",foo2:"bar2"}轉(zhuǎn)換為&foo1=bar1&foo2=bar2。如果是數(shù)組,JQuery將自動(dòng)為不同值對應(yīng)同一個(gè)名稱。例如{foo:["bar1","bar2"]}轉(zhuǎn)換為&foo=bar1&foo=bar2。
7.dataType:
要求為String類型的參數(shù),預(yù)期服務(wù)器返回的數(shù)據(jù)類型。如果不指定,JQuery將自動(dòng)根據(jù)http包mime信息返回responseXML或responseText,并作為回調(diào)函數(shù)參數(shù)傳遞??捎玫念愋腿缦拢?xml:返回XML文檔,可用JQuery處理。 html:返回純文本HTML信息;包含的script標(biāo)簽會(huì)在插入DOM時(shí)執(zhí)行。 script:返回純文本JavaScript代碼。不會(huì)自動(dòng)緩存結(jié)果。除非設(shè)置了cache參數(shù)。注意在遠(yuǎn)程請求時(shí)(不在同一個(gè)域下),所有post請求都將轉(zhuǎn)為get請求。 json:返回JSON數(shù)據(jù)。 jsonp:JSONP格式。使用SONP形式調(diào)用函數(shù)時(shí),例如myurl?callback=?,JQuery將自動(dòng)替換后一個(gè)“?”為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。 text:返回純文本字符串。
8.beforeSend:
要求為Function類型的參數(shù),發(fā)送請求前可以修改XMLHttpRequest對象的函數(shù),例如添加自定義HTTP頭。在beforeSend中如果返回false可以取消本次ajax請求。XMLHttpRequest對象是惟一的參數(shù)。 function(XMLHttpRequest){ this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }
9.complete:
要求為Function類型的參數(shù),請求完成后調(diào)用的回調(diào)函數(shù)(請求成功或失敗時(shí)均調(diào)用)。參數(shù):XMLHttpRequest對象和一個(gè)描述成功請求類型的字符串。 function(XMLHttpRequest, textStatus){ this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }
10.success:
要求為Function類型的參數(shù),請求成功后調(diào)用的回調(diào)函數(shù),有兩個(gè)參數(shù)。 (1)由服務(wù)器返回,并根據(jù)dataType參數(shù)進(jìn)行處理后的數(shù)據(jù)。 (2)描述狀態(tài)的字符串。 function(data, textStatus){ //data可能是xmlDoc、jsonObj、html、text等等 this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }
11.error:
要求為Function類型的參數(shù),請求失敗時(shí)被調(diào)用的函數(shù)。該函數(shù)有3個(gè)參數(shù),即XMLHttpRequest對象、錯(cuò)誤信息、捕獲的錯(cuò)誤對象(可選)。ajax事件函數(shù)如下: function(XMLHttpRequest, textStatus, errorThrown){ //通常情況下textStatus和errorThrown只有其中一個(gè)包含信息 this; //調(diào)用本次ajax請求時(shí)傳遞的options參數(shù) }
12.contentType:
要求為String類型的參數(shù),當(dāng)發(fā)送信息至服務(wù)器時(shí),內(nèi)容編碼類型默認(rèn)為"application/x-www-form-urlencoded"。該默認(rèn)值適合大多數(shù)應(yīng)用場合。
13.dataFilter:
要求為Function類型的參數(shù),給Ajax返回的原始數(shù)據(jù)進(jìn)行預(yù)處理的函數(shù)。提供data和type兩個(gè)參數(shù)。data是Ajax返回的原始數(shù)據(jù),type是調(diào)用jQuery.ajax時(shí)提供的dataType參數(shù)。函數(shù)返回的值將由jQuery進(jìn)一步處理。 function(data, type){ //返回處理后的數(shù)據(jù) return data; }
14.dataFilter:
要求為Function類型的參數(shù),給Ajax返回的原始數(shù)據(jù)進(jìn)行預(yù)處理的函數(shù)。提供data和type兩個(gè)參數(shù)。data是Ajax返回的原始數(shù)據(jù),type是調(diào)用jQuery.ajax時(shí)提供的dataType參數(shù)。函數(shù)返回的值將由jQuery進(jìn)一步處理。 function(data, type){ //返回處理后的數(shù)據(jù) return data; }
15.global:
要求為Boolean類型的參數(shù),默認(rèn)為true。表示是否觸發(fā)全局ajax事件。設(shè)置為false將不會(huì)觸發(fā)全局ajax事件,ajaxStart或ajaxStop可用于控制各種ajax事件。
16.ifModified:
要求為Boolean類型的參數(shù),默認(rèn)為false。僅在服務(wù)器數(shù)據(jù)改變時(shí)獲取新數(shù)據(jù)。服務(wù)器數(shù)據(jù)改變判斷的依據(jù)是Last-Modified頭信息。默認(rèn)值是false,即忽略頭信息。
17.jsonp:
要求為String類型的參數(shù),在一個(gè)jsonp請求中重寫回調(diào)函數(shù)的名字。該值用來替代在"callback=?"這種GET或POST請求中URL參數(shù)里的"callback"部分,例如{jsonp:'onJsonPLoad'}會(huì)導(dǎo)致將"onJsonPLoad=?"傳給服務(wù)器。
18.username:
要求為String類型的參數(shù),用于響應(yīng)HTTP訪問認(rèn)證請求的用戶名。
19.password:
要求為String類型的參數(shù),用于響應(yīng)HTTP訪問認(rèn)證請求的密碼。
20.processData:
要求為Boolean類型的參數(shù),默認(rèn)為true。默認(rèn)情況下,發(fā)送的數(shù)據(jù)將被轉(zhuǎn)換為對象(從技術(shù)角度來講并非字符串)以配合默認(rèn)內(nèi)容類型"application/x-www-form-urlencoded"。如果要發(fā)送DOM樹信息或者其他不希望轉(zhuǎn)換的信息,請?jiān)O(shè)置為false。
21.scriptCharset:
要求為String類型的參數(shù),只有當(dāng)請求時(shí)dataType為"jsonp"或者"script",并且type是GET時(shí)才會(huì)用于強(qiáng)制修改字符集(charset)。通常在本地和遠(yuǎn)程的內(nèi)容編碼不同時(shí)使用
//get()方式 $.ajax({ url:'./data/index.txt', type:'get', dataType:'text', success:function(data){ $('p').html(data); }, error:function(error){ console.log(error) }
//post()方式 $.ajax({ url:'/index', type:'post', data:{name:'張三',age:12}, success:function(data){ $('p').html(data); }, error:function(error){ console.log(error) }
6.一個(gè)前后分離 產(chǎn)生交互的例子:
后臺(tái)server.py
# 通過flask框架搭建后臺(tái) from flask import Flask, request # 創(chuàng)建一個(gè)服務(wù)器對象 app = Flask(__name__) # 解決ajax請求的跨域問題 from flask_cors import CORS CORS(app, supports_credentials=True) # 設(shè)置處理請求的功能(路由route => 接口) # 設(shè)置一個(gè)主頁路由, 對應(yīng)一個(gè)處理主頁的功能方法, 返回主頁信息 @app.route('/') def home_action(): return '<h1 style="color: red">主頁</h1>' # 為ajax登錄請求配置一個(gè)處理登錄的功能 @app.route('/login') def login_action(): # 拿到前臺(tái)數(shù)據(jù), 進(jìn)一步判斷處理 # 需要: 需要賬號(hào)與密碼, 匹配成功與否決定返回結(jié)果 user = request.args['user'] # 'user'是規(guī)定前臺(tái)需要傳入數(shù)據(jù)的key pwd = request.args['pwd'] # print(user) if user == 'abc' and pwd == '123': return "登錄成功" return "登錄失敗" # 啟動(dòng)服務(wù)(該文件作為自啟文件) if __name__ == '__main__': app.run(port="8888")
前臺(tái).html
<h1>請登錄</h1> <form class="fm"> <input id="user" type="text" name="user" placeholder="請輸入用戶名"> <input id="pwd" type="password" name="pwd" placeholder="請輸入密碼"> <input class="sbm" type="submit" value="提交..."> </form>
// 取消表單的默認(rèn)事件 $('.fm').submit(function () { return false; }) // 表單提交完成的是ajax請求 $('.sbm').click(function () { // 前提: 準(zhǔn)備發(fā)送的數(shù)據(jù) var user = $('#user').val(); var pwd = $('#pwd').val(); // 1.通過ajax發(fā)生請求, 獲得后臺(tái)響應(yīng)的結(jié)果 // 2.用得到的結(jié)果來局部渲染頁面內(nèi)容 // 1. $.ajax({ url: "http://127.0.0.1:8888/login", // 接口 data: { // 數(shù)據(jù) user: user, pwd: pwd }, success: function (data) { // 結(jié)果 // 2. doSomething(data); } }) }); // 處理結(jié)果數(shù)據(jù)的功能 function doSomething(data) { // console.log(data) $('h1').text(data) }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jQuery+Ajax+js實(shí)現(xiàn)請求json格式數(shù)據(jù)并渲染到html頁面操作示例
- 為jquery的ajax請求添加超時(shí)timeout時(shí)間的操作方法
- JQuery中Ajax的操作完整例子
- jQuery+Ajax實(shí)現(xiàn)無刷新操作
- jquery插件ajaxupload實(shí)現(xiàn)文件上傳操作
- Jquery操作Ajax方法小結(jié)
- Jquery ajax加載等待執(zhí)行結(jié)束再繼續(xù)執(zhí)行下面代碼操作
- Jquery Ajax請求文件下載操作失敗的原因分析及解決辦法
- jQuery學(xué)習(xí)筆記之 Ajax操作篇(二) - 數(shù)據(jù)傳遞
相關(guān)文章
jQuery html()方法使用不了無法顯示內(nèi)容的問題
jquery中的html方法使用不了,只能用完最基本的innerHTML把內(nèi)容展示出來2014-08-08jQuery 獲取屏幕高度、寬度的簡單實(shí)現(xiàn)案例
下面小編就為大家?guī)硪黄猨Query 獲取屏幕高度、寬度的簡單實(shí)現(xiàn)案例。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05JQuery入門——移除綁定事件unbind方法概述及應(yīng)用
在DOM對象的實(shí)踐操作中,存在用于綁定事件的bind方法,也會(huì)有相應(yīng)的移除綁定事件unbind方法,接下來將介紹unbind方法的使用,感興趣的朋友可以不要錯(cuò)過了啊,或許本文對你有所幫助2013-02-02圖片放大鏡jquery.jqzoom.js使用實(shí)例附放大鏡圖標(biāo)
這篇文章主要介紹了圖片放大鏡jquery.jqzoom.js的使用另附放大鏡圖標(biāo),需要的朋友可以參考下2014-06-06jQuery使用append在html元素后同時(shí)添加多項(xiàng)內(nèi)容的方法
這篇文章主要介紹了jQuery使用append在html元素后同時(shí)添加多項(xiàng)內(nèi)容的方法,實(shí)例分析了jQuery中append追加內(nèi)容的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03