ホームページ  >  記事  >  ウェブフロントエンド  >  ajaxを使ってバックグラウンドで配列の受け渡しをする方法を詳しく解説

ajaxを使ってバックグラウンドで配列の受け渡しをする方法を詳しく解説

亚连
亚连オリジナル
2018-05-22 11:52:263939ブラウズ

この記事では主に、バックグラウンドでの配列の転送と受信に ajax を使用することに関する関連情報を紹介します。記事内の紹介は非常に詳細であり、必要な友人が一緒に学ぶことができます。

はじめに

操作する必要のあるオブジェクトのIDを取得するために、ajaxを使用して非同期に送信しています。このとき、IDごとにオブジェクトを作成して配置できます。配列に変換し、JSON.stringify() を使用します。配列を json としてフォーマットし、バックグラウンドで inputStream 内の json 文字列を解析し、次のように使用します。 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[&#39;book_id&#39;] = countsCheckBox[i].value; 
 booksid[i] = mysendbook_id; 
 } 
 //alert(booksid); 
  var confirmdel= confirm(&#39;确认要删除吗?&#39;); 
  if(confirmdel){ 
  //开始请求删除 
   $.ajax({ 
     url:&#39;selectdelbooks&#39;, 
     data:JSON.stringify(booksid), 
     type:&#39;post&#39;, 
     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);
new JSONArray() json 配列を取得し、ループして必要な属性を解析します:

<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>

上記の js では、選択した各 ID を mysendbook_id の "book_id" 属性に入れてから、このオブジェクトを非同期リクエストを送信する場合は、

JSON.stringify(bookid) を使用して bookid 配列をフォーマットし、json 配列を取得します。

バックグラウンドでそれを受け取る方法を見てみましょう:

1 つは、リストを持つクラスを作成することです。このリストには、bookid の属性が 1 つだけあるクラスが含まれており、アノテーション @ を使用します。 RequestBody この仮パラメータに追加します。しかし、これはさらに面倒です

別の方法は、入力ストリームからデータを取得し、IOUtils.toString を使用して inputStream を文字列に変換し、次に new JSONArray(mybooksid) を使用することです。 ; code>この json 配列を取得します

で、各 json の book_id の属性値を取得します

rrreee

このようにして、選択した ID 値を持つリストを取得します。

データベース内の情報:


ページ上の複数選択:


バックグラウンドで取得される選択された本の ID:


このようにして、ID のセットは次のようになります。が得られ、その後の操作が便利になります。

上記は私があなたのためにまとめたものです。 関連記事:

🎜🎜 Ajax が特殊文字を含むデータを渡す問題を解決する方法🎜🎜🎜🎜🎜 ローカル (ファイル プロトコル) AJAX リクエストをサポートするように Chrome を設定する (グラフィック チュートリアル) 🎜🎜🎜🎜🎜 AJAX ページングの簡単な実装エフェクト (グラフィックとテキスト) チュートリアル)🎜🎜🎜🎜🎜🎜🎜🎜🎜

以上がajaxを使ってバックグラウンドで配列の受け渡しをする方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。