今回は、ajax が配列をバックグラウンドに転送する方法について説明します。 ajax が配列をバックグラウンドに転送するための 注意事項 は何ですか? 以下は実際的なケースです。
はじめに
操作する必要のあるオブジェクトのIDを取得するために、ajaxを使用して非同期に送信しています。このとき、IDごとにオブジェクトを作成して配置できます。配列に変換し、JSON.stringify() を使用してこの配列で json をフォーマットし、バックグラウンドで inputStream で json を解析します。文字列 を使用して、json 配列を取得し、ループして必要な属性を解析します。上記の js では、選択した各 ID を mysendbook_id の "book_id" 属性に置き、非同期リクエストを送信するときに JSON.stringify()
对这个数组进行json的格式化;在后台中再inputStream中解析出我们的json字符串,之后只用:
new JSONArray()
得到json数组,循环解析我们想要的属性:
var countsCheckBox = $("input[type='checkbox']:checked"); var booksid = []; for(var i=0;i<countsCheckBox.length;i++){ //使用[]取得元素是是一个domElement元素,取值需要使用.value, //如果使用countsCheckBox.eq(i) 则是一个Obkject元素,就可以使用val()取值 //alert(countsCheckBox[i].value); mysendbook_id = {}; mysendbook_id['book_id'] = countsCheckBox[i].value; booksid[i] = mysendbook_id; } //alert(booksid); var confirmdel= confirm('确认要删除吗?'); if(confirmdel){ //开始请求删除 $.ajax({ url:'selectdelbooks', data:JSON.stringify(booksid), type:'post', success:function(res){ alert("删除成功"); location.replace("/TheDemo/books/pageBooksShow"); } }); }
上面的js中我们把每一个选中的id放到一个mysendbook_id的“book_id”的属性中,再把这个对象放到booksid的数组中;到发送异步请求时使用
JSON.stringify(bookid)
格式化这个booksid数组,得到一个json的数组。
再看后台我们怎么接收:
一个是做一个类里面有一个list,这个list装的是只有一个属性为bookid的类,再使用注解@RequestBody
加到这个形参上。但是这样比较麻烦;
还有一种是从输入流里面获取数据,使用IOUtils.toString
把inputStream转为字符串,再使用new JSONArray(mybooksid);
JSON.stringify(bookid)
形式を使用してこのオブジェクトを入れます。このbooksid配列を変換してjson配列を取得します。 バックグラウンドでそれを受け取る方法を見てみましょう:
1 つは、リストを含むクラスを作成することです。このリストには、bookid という属性を 1 つだけ持つクラスが含まれており、それをアノテーション@ を使用して追加します。 RequestBody
この仮パラメータについて。しかし、これはさらに面倒です 別の方法は、入力ストリームからデータを取得し、IOUtils.toString
を使用して inputStream を文字列に変換し、次に new JSONArray(mybooksid); を使用することです。
このjson配列を取得
して、各jsonのbook_idの属性値を取得します
<span style="font-family:SimSun;font-size: 10.5pt;"> </span><span style="font-family:KaiTi_GB2312;font-size:14px;"> @RequestMapping("selectdelbooks") public String selectdelbooks(HttpServletRequest request) throws Exception { ServletInputStream inputStream = request.getInputStream(); String mybooksid = IOUtils.toString(inputStream); JSONArray jsonarr = new JSONArray(mybooksid); List<String> book_id =new ArrayList<String>(); for (int i=0;i<jsonarr.length();i++){ book_id.add(((JSONObject)jsonarr.get(i)).getString("book_id")); }...</span>
このようにして、選択したid値を持つリストを取得します。
データベース内の情報: ページ上の複数選択: この事例を読んだ後、あなたは方法をマスターしたと思います。この記事では、さらにエキサイティングな情報を入手してください。php 中国語 Web サイトの他の関連記事にも注目してください。
推奨読書:
以上がAjaxで配列をバックグラウンドに渡す方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。