jquery ajax 向后臺傳遞數(shù)組參數(shù)示例
需求:
在JS中向后臺傳遞數(shù)組參數(shù)
分析:
JS中的數(shù)組是弱類型的可以放任何類型(對象、基本類型),但是如果數(shù)組中放的是對象類型,傳遞到后臺是顯示的只能是對象字符串--[object Object],原因如下:
在后臺接收的時候,只能用request來接收,request.getParameterValues()方法返回的是一個String[],所以,應(yīng)該是在前臺傳輸?shù)臅r候調(diào)用了對象的toString()方法,那么如果依然想傳遞對象怎么辦?涼拌!
但是可以使用JSON字符串來實(shí)現(xiàn),在后臺把JSON字符串解析成JAVA對象。
也許,你要說如果是復(fù)合對象怎么辦,比如如下:
public class Person {
private String username;
private String password;
private Address addr;
}
Person對象里有個Address類型的addr屬性,沒關(guān)系,任何對象最終用到的屬性值都是基本數(shù)據(jù)類型,只需要使用對應(yīng)的包裝類型parseInt、或者parseXXX解析即可。
實(shí)現(xiàn):
OK,原理就是這么個。先看JS如何寫:
var as = [];
var temp = [];
for ( var int = 0; int < 5; int++) {
temp.push('{"k":');
temp.push(int);
temp.push(',"v":');
temp.push(int);
temp.push('}');
as.push(temp.join(""));
}
//Jquery中的方法,具體參考Jquery API
$.post(
"servlet/AjaxServlet?m=putWarningRule",{"aa":as}
);
最終拼成的串就是如下樣式,(只作舉例)
{"k":0,"v":0}
后臺接收,不討論任何框架,只需要HttpServletRequest即可
String[] jsonArr = request.getParameterValues("aa[]");
有一點(diǎn)需要注意,在js中傳參的時候參數(shù)名叫"aa",而在后臺接收的時候卻是"aa[]",這里應(yīng)該是Jquery做了轉(zhuǎn)換,所以最好的方式就是在JS中就改為"aa[]",之所以這里沒有寫"[]"是為了說明問題??梢允褂萌缦路绞酱蛴equest中的所有參數(shù)
Enumeration<String> names = request.getParameterNames();
while (names.hasMoreElements()) {
String string = (String) names.nextElement();
System.out.println(string);
}
OK,至此為止,已經(jīng)接收完畢,剩下的就是如何將一個JSON字符串轉(zhuǎn)成一個POJO了。我使用jsontools-core-1.7.jar,此jar包依賴antlr-2.7.7.jar,自行到代碼庫中下載,下載完畢,導(dǎo)入classpath,寫一個簡單的工具類,主要有這么2個方法:
/**
* 將對象轉(zhuǎn)換為JSON格式的字符串
* @param obj
* @return 返回JSON字符串
*/
public static String toJSONAsString(Object obj){
try {
return JSONMapper.toJSON(obj).render(false);
} catch (MapperException e) {
e.printStackTrace();
}
return null;
}
@SuppressWarnings("unchecked")
public static <T> T jsonToObject(String jsonStr, Class<T> targetClass) throws TokenStreamException, RecognitionException, MapperException{
JSONValue jv = new JSONParser(new StringReader(jsonStr)).nextValue();
return (T) JSONMapper.toJava(jv,targetClass);
}
//test
public static void main(String[] args) throws Exception {
Person p = new Person();
p.setK("a");
p.setV("v");
String json = toJSONAsString(p);
Person np = jsonToObject(json,Person.class);
System.out.println(np.getK()+"=="+np.getV());
}
request取到值后,遍歷數(shù)組,挨個轉(zhuǎn)換
Person p = JSONUtils.jsonToObject(jsonArr[0], Person.class);
Person類如下:
public class Person {
private String k;
private String v;
public String getK() {
return k;
}
public void setK(String k) {
this.k = k;
}
public String getV() {
return v;
}
public void setV(String v) {
this.v = v;
}
}
- jquery實(shí)現(xiàn)ajax提交form表單的方法總結(jié)
- jquery中ajax使用error調(diào)試錯誤的方法
- jquery中ajax處理跨域的三大方式
- jquery ajax提交表單數(shù)據(jù)的兩種方式
- jquery ajax例子返回值詳解
- JQuery的Ajax請求實(shí)現(xiàn)局部刷新的簡單實(shí)例
- JQuery AJAX提交中文亂碼的解決方案
- JQuery處理json與ajax返回JSON實(shí)例代碼
- Jquery中ajax方法data參數(shù)的用法小結(jié)
- jQuery AJAX應(yīng)用實(shí)例總結(jié)
相關(guān)文章
Jquery中ajax提交表單幾種方法(get、post兩種方法)
ajax技術(shù)帶給我們的是良好的用戶體驗(yàn),同時,使用jquery可以簡化開發(fā),提高工作效率,接下來,腳本之家小編給大家分享Jquery中ajax提交表單幾種方法,需要的朋友可以參考下2015-09-09ajax、axios和fetch之間優(yōu)缺點(diǎn)重點(diǎn)對比總結(jié)
今天被問到用沒用過ajax axios,我回答經(jīng)常用axios,但ajax用的比較少,下面這篇文章主要給大家介紹了關(guān)于ajax、axios和fetch之間優(yōu)缺點(diǎn)重點(diǎn)對比總結(jié)的相關(guān)資料,需要的朋友可以參考下2022-12-12React+ajax+java實(shí)現(xiàn)上傳圖片并預(yù)覽功能
這篇文章主要介紹了React+ajax+java實(shí)現(xiàn)上傳圖片并預(yù)覽功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05基于Ajax實(shí)現(xiàn)下拉框聯(lián)動顯示數(shù)據(jù)
本篇文章給大家介紹基于ajax實(shí)現(xiàn)下拉框聯(lián)動顯示數(shù)據(jù),代碼非常簡單,需要的朋友可以參考下2015-09-09Jquery具體實(shí)例介紹AJAX何時用,AJAX應(yīng)該在什么地方用
ajax是一個非常方便的工具,具有和表單相同的功能完成前端和后臺之間的交互,起到局部刷新的作用,那么,大家知道ajax該何時用,用在哪些地方嗎?下面小編給大家分享Jquery具體實(shí)例介紹AJAX何時用,AJAX應(yīng)該在什么地方用,需要的朋友可以參考下2015-10-10