今回は、Ajax+Struts2で配列フォームを受け取るための注意事項を紹介します。以下は実際的なケースです。
以下、通常形式とajaxの2つの方法で説明します。まず、次のエンティティ、アクション、および JSP があります。
Student.java
public class Student { private String name; private String num; } StudentAction.java public class StudentAction extends ActionSupport { private List<Student> lstStu; }
xy.jsp
<script type="text/javascript"> var stus = []; stus.push({num:"1",name:"xy1"}); stus.push({num:"2",name:"xy2"}); stus.push({num:"3",name:"xy3"}); </script>
では、xy.jspのスクリプト領域に次のコードを記述します。
通常のフォームフォーム - 配列を走査し、フォームの隠しフィールドを構築します
var htmlContent = ""; for(var i=0;i<stus.length;i++){ htmlContent += "<input type='hidden' name='lstStu[" + i + "].name' value='" + stus[i].name + " ' />"; htmlContent += "<input type='hidden' name='lstStu[" + i + "].num' value='" + stus[i].num + " ' />"; }
特殊なケース
<input type='hidden' name='lstStu.name' value='xy1' /> <input type='hidden' name='lstStu.name' value='xy2' /> <input type='hidden' name='lstStu.name' value='xy3' />
単一の属性を渡すと、Struts はそれを認識し、3 人の異なる生徒を表すことができます。ただし、Struts はその組み合わせを知らないため、2 つの属性を渡すことは機能しません。お勧めしません。
ajax フォーム - 配列を走査して json オブジェクトを構築します
var param = {}; for(var i=0;i<stus.length;i++){ param["lstStu[" + i + "].name"] = stus[i].name; param["lstStu[" + i + "].num"] = stus[i].num; } $.ajax({ data:param });
実際、このような json オブジェクトを構築しました
data:{ lstStu[0].num:"1",lstStu[0].name:"xy1", lstStu[1].num:"2",lstStu[1].name:"xy2", lstStu[2].num:"3",lstStu[0].name:"xy3" }
この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、お支払いください。 PHP 中国語 Web サイトの他の関連記事にも注目してください。
推奨読書:
以上がAjax+Struts2は配列形式を受け取ります(コード付き)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。