var arr = [];\x0d\x0avar $test = $("input[name=test]");//假設(shè)name為test\x0d\x0afor(var i=0;i
公司主營(yíng)業(yè)務(wù):網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。成都創(chuàng)新互聯(lián)是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。成都創(chuàng)新互聯(lián)推出青白江免費(fèi)做網(wǎng)站回饋大家。
回答于?2022-11-16
jquery是js編寫(xiě)的框架 可以方便的 實(shí)現(xiàn)復(fù)雜的效果。
jQuery是一套跨瀏覽器的JavaScript庫(kù),簡(jiǎn)化HTML與JavaScript之間的操作。它是輕量級(jí)的js庫(kù) ,兼容CSS3,還兼容各種瀏覽器,jQuery2.0及后續(xù)版本不再支持IE6/7/8瀏覽器。由John Resig在2006年1月的BarCamp NYC上發(fā)布第一個(gè)版本。目前是由 Dave Methvin 領(lǐng)導(dǎo)的開(kāi)發(fā)團(tuán)隊(duì)進(jìn)行開(kāi)發(fā)。jQuery使用戶能更方便地處理HTML documents、events、實(shí)現(xiàn)動(dòng)畫(huà)效果,并且方便地為網(wǎng)站提供AJAX交互。jQuery還有一個(gè)比較大的優(yōu)勢(shì)是,它的文檔說(shuō)明很全,而且各種應(yīng)用也說(shuō)得很詳細(xì),同時(shí)還有許多成熟的插件可供選擇。jQuery能夠使用戶的html頁(yè)面保持代碼和html內(nèi)容分離,也就是說(shuō),不用再在html里面插入一堆js來(lái)調(diào)用命令了,只需定義id即可。
Java軟件開(kāi)發(fā)中,后臺(tái)中我們可以通過(guò)各種框架,像SSH等進(jìn)行對(duì)代碼的封裝,方便我們對(duì)Java代碼的編寫(xiě),例如,Struts,SpringMVC對(duì)從前臺(tái)到action的流程進(jìn)行封裝控制,使我們只需要進(jìn)行一些簡(jiǎn)單配置就可以實(shí)現(xiàn);而Spring進(jìn)行了對(duì)各種對(duì)象的管理進(jìn)行封裝,提供了AOP編程的方式,大大方便了我們;而Hibernate和IBatis則是對(duì)JDBC代碼進(jìn)行封裝,不需要我們每次都寫(xiě)那些重復(fù)而繁雜的JDBC代碼。
前臺(tái)呢,對(duì)于頁(yè)面一些效果,驗(yàn)證等,我們都是通過(guò)JavaScript語(yǔ)言進(jìn)行完成的,但是它也就像我們的Java代碼一樣,是最前臺(tái)語(yǔ)言最基礎(chǔ)的,而JQuery則是對(duì)js代碼進(jìn)行封裝方便我們前臺(tái)代碼的編寫(xiě),而且它還有一個(gè)非常大的優(yōu)勢(shì)就是解決了瀏覽器的兼容問(wèn)題,這也是我們使用它非常重要的原因之一。
而現(xiàn)在為了滿足用戶的需求,Ajax(Asynchronous Javascript + XML)異步刷新起到了無(wú)可比擬的作用,以前寫(xiě)Ajax操作,總是需要我們想JDBC代碼一樣進(jìn)行幾個(gè)必備的步驟:
AJAX——核心XMLHttpRequest對(duì)象,而JQuery也對(duì)Ajax異步操作進(jìn)行了封裝,這里看一下幾種常用的方式。 $.ajax,$.post, $.get, $.getJSON。
一, $.ajax,這個(gè)是JQuery對(duì)ajax封裝的最基礎(chǔ)步,通過(guò)使用這個(gè)函數(shù)可以完成異步通訊的所有功能。也就是說(shuō)什么情況下我們都可以通過(guò)此方法進(jìn)行異步刷新的操作。但是它的參數(shù)較多,有的時(shí)候可能會(huì)麻煩一些??匆幌鲁S玫膮?shù):
var configObj = {
method //數(shù)據(jù)的提交方式:get和post
url //數(shù)據(jù)的提交路勁
async //是否支持異步刷新,默認(rèn)是true
data //需要提交的數(shù)據(jù)
dataType //服務(wù)器返回?cái)?shù)據(jù)的類型,例如xml,String,Json等
success //請(qǐng)求成功后的回調(diào)函數(shù)
error //請(qǐng)求失敗后的回調(diào)函數(shù)
}
$.ajax(configObj);//通過(guò)$.ajax函數(shù)進(jìn)行調(diào)用。
二,$.post,這個(gè)函數(shù)其實(shí)就是對(duì)$.ajax進(jìn)行了更進(jìn)一步的封裝,減少了參數(shù),簡(jiǎn)化了操作,但是運(yùn)用的范圍更小了。$.post簡(jiǎn)化了數(shù)據(jù)提交方式,只能采用POST方式提交。只能是異步訪問(wèn)服務(wù)器,不能同步訪問(wèn),不能進(jìn)行錯(cuò)誤處理。在滿足這些情況下,我們可以使用這個(gè)函數(shù)來(lái)方便我們的編程,它的主要幾個(gè)參數(shù),像method,async等進(jìn)行了默認(rèn)設(shè)置,我們不可以改變的。例子不再介紹。
url:發(fā)送請(qǐng)求地址。
data:待發(fā)送 Key/value 參數(shù)。
callback:發(fā)送成功時(shí)回調(diào)函數(shù)。
type:返回內(nèi)容格式,xml, html, script, json, text,_default。
三,$.get,和$.post一樣,這個(gè)函數(shù)是對(duì)get方法的提交數(shù)據(jù)進(jìn)行封裝,只能使用在get提交數(shù)據(jù)解決異步刷新的方式上,使用方式和上邊的也差不多。這里不再演示。
四, $.getJSON,這個(gè)是進(jìn)一步的封裝,也就是對(duì)返回?cái)?shù)據(jù)類型為Json進(jìn)行操作。里邊就三個(gè)參數(shù),需要我們?cè)O(shè)置,非常簡(jiǎn)單:url,[data],[callback]。
其實(shí)會(huì)了$.ajax方法,其它的就都會(huì)使用了,都是一樣的,其實(shí)非常簡(jiǎn)單。
但是這里還有一個(gè)問(wèn)題,比較麻煩,就是如果頁(yè)面數(shù)據(jù)量比較大,該怎么辦呢?在常規(guī)表單的處理中,我們使用框架Struts2可以通過(guò)域驅(qū)動(dòng)模式進(jìn)行自動(dòng)獲取封裝,那么通過(guò)ajax,如何進(jìn)行封裝呢?這里JQuery有一個(gè)插件,Jquery Form,通過(guò)引入此js文件,我們可以模仿表單Form來(lái)支持Struts2的域驅(qū)動(dòng)模式,進(jìn)行自動(dòng)數(shù)據(jù)的封裝。
這樣我們就不用再進(jìn)行數(shù)據(jù)data的封裝處理,大大簡(jiǎn)化了我們ajax的操作這樣異步刷新的操作。綜上為JQuery中ajax的操作,感覺(jué)使用多了,和form表單的處理還是非常相似的,只不過(guò)實(shí)現(xiàn)的功能不一樣罷了。學(xué)習(xí)編程,其實(shí)就是學(xué)習(xí)對(duì)數(shù)據(jù)的流轉(zhuǎn)處理,如何從前臺(tái)獲取,傳輸?shù)椒?wù)器進(jìn)行相應(yīng)的處理,然后返回,進(jìn)行相關(guān)的顯示,把這個(gè)流程通過(guò)一些技術(shù)實(shí)現(xiàn),就完成了軟件的開(kāi)發(fā),感覺(jué)還是非常有意思的。
更多資料請(qǐng)參考
將ajax的發(fā)送行為封裝到一個(gè)方法中。
然后用setTimeout延時(shí)執(zhí)行就可以了。
如果需要多次循環(huán)執(zhí)行,也可以用setInterval。
它的底層實(shí)現(xiàn)包括下面幾個(gè)方面:1.jQuery底層在實(shí)現(xiàn)ajax功能時(shí),調(diào)用了瀏覽器中的XMLHttpRequest對(duì)象,在最新的2.0版本后,由于不考慮IE瀏覽器的支持,直接使用該對(duì)象獲取用戶請(qǐng)求的數(shù)據(jù),包括地址和參數(shù)等。2.它將對(duì)象打開(kāi)請(qǐng)求地址時(shí)的相關(guān)參數(shù)封裝在相關(guān)函數(shù)如ajax()的配置項(xiàng)中,一旦傳入了必需選項(xiàng),則直接調(diào)用相應(yīng)的send()方法進(jìn)行數(shù)據(jù)的請(qǐng)求。3.jQuery底層將對(duì)象請(qǐng)求后返回的數(shù)據(jù)結(jié)果,直接封裝到相關(guān)函數(shù)的success方法中,所以,一旦異步請(qǐng)求成功,返回的數(shù)據(jù)對(duì)象直接注入到方法中,因此,可以調(diào)用success方法獲取服務(wù)端返回的數(shù)據(jù)。我之前在黑馬程序員的免費(fèi)視頻中看到過(guò)ajax和jQuery的相關(guān)視頻,講的都還挺不錯(cuò)的。
首先你的這個(gè)實(shí)現(xiàn)邏輯就有問(wèn)題,怎么可能會(huì)想到用for 去做n次ajax提交呢,你得知道你現(xiàn)在上面寫(xiě)的這種ajax提交方式為異步方式,何為異步,就是當(dāng)ajax請(qǐng)求發(fā)出后當(dāng)前邏輯就認(rèn)為你的這次請(qǐng)求完成了,當(dāng)前邏輯會(huì)繼續(xù)往下執(zhí)行而不會(huì)去管你的這個(gè)ajax請(qǐng)求是否執(zhí)行完并成功返回的,如你for了10次,那么for只會(huì)管執(zhí)行10個(gè)ajax提交,因?yàn)閍jax是異步方式,所以你在for里面無(wú)法控制你的這10次ajax是否都正常的執(zhí)行并返回的,這10次ajax提交的返回是無(wú)序的。所以一般都不會(huì)用這樣的邏輯來(lái)處理問(wèn)題,如果實(shí)在非得要用這種邏輯,那么得將ajax請(qǐng)求方式改成同步方式,即將async:false 改成 async:true,這樣就可能如你的預(yù)期,一個(gè)ajax執(zhí)行完正常返回后才行下一個(gè)ajax,
==================================================================
哦,那是我記錯(cuò)咯,如果你實(shí)在要用這種實(shí)現(xiàn)邏輯的話,我倒建議你不要這么寫(xiě),類似下面這種寫(xiě)法應(yīng)該好處理些的:
for (var i=0; i9; i++)
{
var post_data = new Array('rand':new Date().getMilliseconds())
var post_retn = eval('('+ $.ajax({type:'post', data:post_data, url:'xxxxxrand=' + new Date().getMilliseconds(), async:false}).responseText +')');
alert(post_retn);
}