ホームページ > ウェブフロントエンド > jsチュートリアル > 配列パラメータをバックグラウンドに渡すjquery ajaxの例

配列パラメータをバックグラウンドに渡すjquery ajaxの例

高洛峰
リリース: 2017-01-09 14:28:21
オリジナル
1190 人が閲覧しました

要件:
配列パラメータをJSのバックグラウンドに転送する

分析:
JSの配列は弱く型指定されており、任意の型(オブジェクト、基本型)を含めることができますが、配列がオブジェクト型の場合、何がバックグラウンドに渡されるか? 以下の理由により、表示できるのはオブジェクト文字列--[object Object]のみです:
バックグラウンドで受信する場合、request.getParameterValues() メソッドは String[ を返すだけです。オブジェクトの toString() メソッドはフォアグラウンド送信中に呼び出されますが、それでもオブジェクトを転送したい場合はどうすればよいでしょうか。サラダ!
ただし、JSON 文字列を使用して実装でき、JSON 文字列はバックグラウンドで Java オブジェクトに解析されます。

おそらく、次のような複合オブジェクトの場合にどうするかを言いたいでしょう:

public class Person { 
private String username; 
private String password; 
private Address addr; 
}
ログイン後にコピー

Person オブジェクトに Address 型の addr 属性がありますが、その属性値は問題ではありません。すべてのオブジェクトで最終的に使用されるのは、基本的なデータ型です。解析できるのは、対応するパッケージ化型の parseInt または parseXXX のみです。

実装:
OK、これが原則です。まずは JS の書き方を見てみましょう:

var as = []; 
var temp = []; 
for ( var int = 0; int < 5; int++) { 
temp.push(&#39;{"k":&#39;); 
temp.push(int); 
temp.push(&#39;,"v":&#39;); 
temp.push(int); 
temp.push(&#39;}&#39;); 
as.push(temp.join("")); 
} 
//Jquery中的方法,具体参考Jquery API 
$.post( 
"servlet/AjaxServlet?m=putWarningRule",{"aa":as} 
);
ログイン後にコピー

最後の文字列は次のスタイルです。(例として)

{"k":0,"v":0}
ログイン後にコピー

バックエンドの受信、フレームワークについては説明しません。必要なのは HttpServletRequest のみです

String[] jsonArr = request.getParameterValues("aa[]");
ログイン後にコピー

注意すべき点が 1 つあります。 jsではパラメータを渡すときのパラメータ名は「aa」ですが、バックグラウンドで受け取るときは「aa[]」になります。ここでJqueryが変換する必要があるため、「aa[」に変更するのが最善の方法です。 ]」を JS で記述しているのに、ここで「[]」を書かないのは問題を説明するためです。次のメソッドを使用してリクエスト内のすべてのパラメータを出力できます

Enumeration<String> names = request.getParameterNames(); 
while (names.hasMoreElements()) { 
String string = (String) names.nextElement(); 
System.out.println(string); 
}
ログイン後にコピー

OK。この時点で、残っているのは JSON 文字列を POJO に変換する方法だけです。私は jsontools-core-1.7.jar を使用します。この jar パッケージは antlr-2.7.7.jar に依存しています。ダウンロード後、クラスパスをインポートして簡単なツール クラスを作成します。メソッド:

/** 
* 将对象转换为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 が値を取得した後、配列を走査し、次のように

Person p = JSONUtils.jsonToObject(jsonArr[0], Person.class);
ログイン後にコピー

person クラスを 1 つずつ変換します:

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 ajax の例については、お支払いください関連記事については、PHP 中国語 Web サイトに注目してください。


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート