通過(guò)實(shí)例解析jQ Ajax操作相關(guān)原理
什么是AJAX
AJAX = 異步的javascript和XML(Asynchronous Javascript and XML)
它不是一門編程語(yǔ)言,而是利用JavaScript在保證頁(yè)面不被刷新、頁(yè)面鏈接不改變的情況下與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁(yè)的技術(shù)。
對(duì)于傳統(tǒng)的網(wǎng)頁(yè),如果想更新內(nèi)容,那么必須要刷新整個(gè)頁(yè)面,但有了Ajax,便可以在頁(yè)面不被全部刷新的情況下更新其內(nèi)容。在這個(gè)過(guò)程中,頁(yè)面實(shí)際上是在后臺(tái)與服務(wù)器進(jìn)行了數(shù)據(jù)交互,獲得數(shù)據(jù)之后,再利用JavaScript改變頁(yè)面,這樣頁(yè)面內(nèi)容就會(huì)更新了。(微博頁(yè)面加載過(guò)程的例子,加載一會(huì) 下方才會(huì)出現(xiàn)內(nèi)容,這其實(shí)就是Ajax加載的過(guò)程。)
簡(jiǎn)言之,在不重載整個(gè)網(wǎng)頁(yè)的情況下,AJAX通過(guò)后臺(tái)加載數(shù)據(jù),并在網(wǎng)頁(yè)上進(jìn)行顯示。
通過(guò) jQuery AJAX 方法,您能夠使用 HTTP Get 和 HTTP Post 從遠(yuǎn)程服務(wù)器上請(qǐng)求文本、HTML、XML 或 JSON - 同時(shí)您能夠把這些外部數(shù)據(jù)直接載入網(wǎng)頁(yè)的被選元素中。
1.jQuery的load()方法
jQuery load()方法是簡(jiǎn)單但強(qiáng)大的AJAX方法。
load()方法從服務(wù)器加載數(shù)據(jù),并把返回的數(shù)據(jù)放入被選元素中。
語(yǔ)法:
$("selector").load(url,data,callback);
必須的url參數(shù)規(guī)定記載的url地址
可選的data參數(shù)規(guī)定與請(qǐng)求一同發(fā)送的查詢字符串鍵/值對(duì)的集合
可選的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è)中應(yīng)用,也就是說(shuō)要在服務(wù)器上運(yùn)行,本地調(diào)試需要搭建后端本地環(huán)境。
2. jquery的getJSON方法
jQuery的AJAX中使用getJSON()方法異步加載JSON格式數(shù)據(jù)。獲取服務(wù)器中的數(shù)據(jù),并對(duì)數(shù)據(jù)進(jìn)行解析,顯示到頁(yè)面中
語(yǔ)法: $.getJSON(url,[data],[callback])
url參數(shù)為請(qǐng)求加載json格式文件的服務(wù)器地址,可選項(xiàng)data參數(shù)為請(qǐng)求時(shí)發(fā)送的數(shù)據(jù),callback參數(shù)為數(shù)據(jù)請(qǐng)求成功后執(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() 方法通過(guò) HTTP GET 請(qǐng)求從服務(wù)器上請(qǐng)求數(shù)據(jù)
語(yǔ)法:$.get(URL,callback);
url參數(shù)規(guī)定你請(qǐng)求的路徑,是必需參數(shù),callback參數(shù)為數(shù)據(jù)請(qǐng)求成功后執(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é)果返回頁(yè)面#
語(yǔ)法:$.post(URL,data,callback);
url參數(shù)規(guī)定你請(qǐng)求的路徑,是必需參數(shù),可選的data參數(shù)是連同請(qǐng)求發(fā)送的數(shù)據(jù)。可選的callback參數(shù)為數(shù)據(jù)請(qǐng)求成功后執(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)前頁(yè)地址)發(fā)送請(qǐng)求的地址。
2.type:
要求為String類型的參數(shù),請(qǐng)求方式(post或get)默認(rèn)為get。注意其他http請(qǐng)求方法,例如put和delete也可以使用,但僅部分瀏覽器支持。
3.timeout:
要求為Number類型的參數(shù),設(shè)置請(qǐng)求超時(shí)時(shí)間(毫秒)。此設(shè)置將覆蓋$.ajaxSetup()方法的全局設(shè)置。
4.async:
要求為Boolean類型的參數(shù),默認(rèn)設(shè)置為true,所有請(qǐng)求均為異步請(qǐng)求。如果需要發(fā)送同步請(qǐng)求,請(qǐng)將此選項(xiàng)設(shè)置為false。注意,同步請(qǐng)求將鎖住瀏覽器,用戶其他操作必須等待請(qǐng)求完成才可以執(zhí)行。
5.cache:
要求為Boolean類型的參數(shù),默認(rèn)為true(當(dāng)dataType為script時(shí),默認(rèn)為false),設(shè)置為false將不會(huì)從瀏覽器緩存中加載請(qǐng)求信息。
6.data:
要求為Object或String類型的參數(shù),發(fā)送到服務(wù)器的數(shù)據(jù)。如果已經(jīng)不是字符串,將自動(dòng)轉(zhuǎn)換為字符串格式。get請(qǐng)求中將附加在url后。防止這種自動(dòng)轉(zhuǎn)換,可以查看 processData選項(xiàng)。對(duì)象必須為key/value格式,例如{foo1:"bar1",foo2:"bar2"}轉(zhuǎn)換為&foo1=bar1&foo2=bar2。如果是數(shù)組,JQuery將自動(dòng)為不同值對(duì)應(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)程請(qǐng)求時(shí)(不在同一個(gè)域下),所有post請(qǐng)求都將轉(zhuǎn)為get請(qǐng)求。 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ā)送請(qǐng)求前可以修改XMLHttpRequest對(duì)象的函數(shù),例如添加自定義HTTP頭。在beforeSend中如果返回false可以取消本次ajax請(qǐng)求。XMLHttpRequest對(duì)象是惟一的參數(shù)。 function(XMLHttpRequest){ this; //調(diào)用本次ajax請(qǐng)求時(shí)傳遞的options參數(shù) }
9.complete:
要求為Function類型的參數(shù),請(qǐng)求完成后調(diào)用的回調(diào)函數(shù)(請(qǐng)求成功或失敗時(shí)均調(diào)用)。參數(shù):XMLHttpRequest對(duì)象和一個(gè)描述成功請(qǐng)求類型的字符串。 function(XMLHttpRequest, textStatus){ this; //調(diào)用本次ajax請(qǐng)求時(shí)傳遞的options參數(shù) }
10.success:
要求為Function類型的參數(shù),請(qǐng)求成功后調(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請(qǐng)求時(shí)傳遞的options參數(shù) }
11.error:
要求為Function類型的參數(shù),請(qǐng)求失敗時(shí)被調(diào)用的函數(shù)。該函數(shù)有3個(gè)參數(shù),即XMLHttpRequest對(duì)象、錯(cuò)誤信息、捕獲的錯(cuò)誤對(duì)象(可選)。ajax事件函數(shù)如下: function(XMLHttpRequest, textStatus, errorThrown){ //通常情況下textStatus和errorThrown只有其中一個(gè)包含信息 this; //調(diào)用本次ajax請(qǐng)求時(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)用場(chǎ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請(qǐng)求中重寫回調(diào)函數(shù)的名字。該值用來(lái)替代在"callback=?"這種GET或POST請(qǐng)求中URL參數(shù)里的"callback"部分,例如{jsonp:'onJsonPLoad'}會(huì)導(dǎo)致將"onJsonPLoad=?"傳給服務(wù)器。
18.username:
要求為String類型的參數(shù),用于響應(yīng)HTTP訪問(wèn)認(rèn)證請(qǐng)求的用戶名。
19.password:
要求為String類型的參數(shù),用于響應(yīng)HTTP訪問(wèn)認(rèn)證請(qǐng)求的密碼。
20.processData:
要求為Boolean類型的參數(shù),默認(rèn)為true。默認(rèn)情況下,發(fā)送的數(shù)據(jù)將被轉(zhuǎn)換為對(duì)象(從技術(shù)角度來(lái)講并非字符串)以配合默認(rèn)內(nèi)容類型"application/x-www-form-urlencoded"。如果要發(fā)送DOM樹信息或者其他不希望轉(zhuǎn)換的信息,請(qǐng)?jiān)O(shè)置為false。
21.scriptCharset:
要求為String類型的參數(shù),只有當(dāng)請(qǐ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
# 通過(guò)flask框架搭建后臺(tái)
from flask import Flask, request
# 創(chuàng)建一個(gè)服務(wù)器對(duì)象
app = Flask(__name__)
# 解決ajax請(qǐng)求的跨域問(wèn)題
from flask_cors import CORS
CORS(app, supports_credentials=True)
# 設(shè)置處理請(qǐng)求的功能(路由route => 接口)
# 設(shè)置一個(gè)主頁(yè)路由, 對(duì)應(yīng)一個(gè)處理主頁(yè)的功能方法, 返回主頁(yè)信息
@app.route('/')
def home_action():
return '<h1 style="color: red">主頁(yè)</h1>'
# 為ajax登錄請(qǐng)求配置一個(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>請(qǐng)登錄</h1> <form class="fm"> <input id="user" type="text" name="user" placeholder="請(qǐng)輸入用戶名"> <input id="pwd" type="password" name="pwd" placeholder="請(qǐng)輸入密碼"> <input class="sbm" type="submit" value="提交..."> </form>
// 取消表單的默認(rèn)事件
$('.fm').submit(function () { return false; })
// 表單提交完成的是ajax請(qǐng)求
$('.sbm').click(function () {
// 前提: 準(zhǔn)備發(fā)送的數(shù)據(jù)
var user = $('#user').val();
var pwd = $('#pwd').val();
// 1.通過(guò)ajax發(fā)生請(qǐng)求, 獲得后臺(tái)響應(yīng)的結(jié)果
// 2.用得到的結(jié)果來(lái)局部渲染頁(yè)面內(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)
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jQuery+Ajax+js實(shí)現(xiàn)請(qǐng)求json格式數(shù)據(jù)并渲染到html頁(yè)面操作示例
- 為jquery的ajax請(qǐng)求添加超時(shí)timeout時(shí)間的操作方法
- JQuery中Ajax的操作完整例子
- jQuery+Ajax實(shí)現(xiàn)無(wú)刷新操作
- jquery插件ajaxupload實(shí)現(xiàn)文件上傳操作
- Jquery操作Ajax方法小結(jié)
- Jquery ajax加載等待執(zhí)行結(jié)束再繼續(xù)執(zhí)行下面代碼操作
- Jquery Ajax請(qǐng)求文件下載操作失敗的原因分析及解決辦法
- jQuery學(xué)習(xí)筆記之 Ajax操作篇(二) - 數(shù)據(jù)傳遞
相關(guān)文章
jquery怎樣實(shí)現(xiàn)ajax聯(lián)動(dòng)框(二)
ajax聯(lián)動(dòng)框想必大家早有所耳聞,接下來(lái)將介紹jquery實(shí)現(xiàn)另一種形式的聯(lián)動(dòng)框,右邊的聯(lián)動(dòng)框用jquery生成,仿照上篇的js方法修改的,感興趣的你可以參考下希望可以幫助到你2013-03-03
使用js dom和jquery分別實(shí)現(xiàn)簡(jiǎn)單增刪改
今天學(xué)了jquery框架的簡(jiǎn)單使用。于是用它實(shí)現(xiàn)簡(jiǎn)單的增刪改,接著也用原始的javascript實(shí)現(xiàn)同樣的功能,兩者對(duì)比可以看出jquery的強(qiáng)大2014-09-09
jQuery實(shí)現(xiàn)平滑滾動(dòng)的標(biāo)簽分欄切換效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)平滑滾動(dòng)的標(biāo)簽分欄切換效果,涉及jquery鼠標(biāo)事件及頁(yè)面元素樣式的動(dòng)態(tài)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08
jqGrid日期格式的判斷示例代碼(開(kāi)始日期與結(jié)束日期)
jqGrid日期格式的判斷示例代碼(開(kāi)始日期與結(jié)束日期)。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11
jquery對(duì)標(biāo)簽添加只讀(readonly)或者禁用(disabled)屬性
這篇文章主要介紹了jquery對(duì)標(biāo)簽添加只讀(readonly)或者禁用(disabled)屬性,jQuery是一個(gè)JavaScript庫(kù)。極大地簡(jiǎn)化了JavaScript編程,下面關(guān)于其詳細(xì)介紹,需要的小伙伴可以參考一下2022-03-03
jQuery插件echarts實(shí)現(xiàn)的多柱子柱狀圖效果示例【附demo源碼下載】
這篇文章主要介紹了jQuery插件echarts實(shí)現(xiàn)的多柱子柱狀圖效果,結(jié)合完整實(shí)例形式分析了echarts繪制多柱子柱狀圖效果的操作步驟與相關(guān)實(shí)現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
jQuery擴(kuò)展_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了jQuery擴(kuò)展,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07

