ホームページ >ウェブフロントエンド >jsチュートリアル >Ajaxで配列をバックグラウンドに渡す方法

Ajaxで配列をバックグラウンドに渡す方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-03-31 15:08:2410181ブラウズ

今回は、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><p style="text-align: left;">上面的js中我们把每一个选中的id放到一个mysendbook_id的“book_id”的属性中,再把这个对象放到booksid的数组中;到发送异步请求时使用</p>
<p style="text-align: left;"><code>JSON.stringify(bookid)</code>格式化这个booksid数组,得到一个json的数组。</p>
<p style="text-align: left;"><strong>再看后台我们怎么接收:</strong></p>
<p style="text-align: left;">一个是做一个类里面有一个list,这个list装的是只有一个属性为bookid的类,再使用注解<code>@RequestBody</code>加到这个形参上。但是这样比较麻烦;</p>
<p style="text-align: left;">还有一种是从输入流里面获取数据,使用<code>IOUtils.toString </code>把inputStream转为字符串,再使用<code>new JSONArray(mybooksid);</code></p>
<code>JSON.stringify(bookid)</code> 形式を使用してこのオブジェクトを入れます。このbooksid配列を変換してjson配列を取得します。 <p style="text-align: left;"></p>
<p style="text-align: left;">バックグラウンドでそれを受け取る方法を見てみましょう: </p>
<p style="text-align: left;"></p> 1 つは、リストを含むクラスを作成することです。このリストには、bookid という属性を 1 つだけ持つクラスが含まれており、それをアノテーション <code>@ を使用して追加します。 RequestBody</code> この仮パラメータについて。しかし、これはさらに面倒です <p style="text-align: left;"><img src="/static/imghwm/default1.png" data-src="https://img.php.cn/upload/article/000/061/021/ede892effff2e96dadf4e84cefd87ad7-0.png?x-oss-process=image/resize,p_40" class="lazy" alt=""> 別の方法は、入力ストリームからデータを取得し、<code>IOUtils.toString </code> を使用して inputStream を文字列に変換し、次に <code>new JSONArray(mybooksid); を使用することです。 </code>このjson配列を取得</p>
<p style="text-align: left;">して、各jsonのbook_idの属性値を取得します</p>
<pre class="brush:php;toolbar:false"><span> </span><span> @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></jsonarr.length></string></string></span>

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

データベース内の情報:

ページ上の複数選択:

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

この事例を読んだ後、あなたは方法をマスターしたと思います。この記事では、さらにエキサイティングな情報を入手してください。php 中国語 Web サイトの他の関連記事にも注目してください。
推奨読書:

AJAX ページング効果を実装する方法

🎜 Ajax を使用してフォームを送信し、JSON データを受信する方法 🎜🎜🎜🎜🎜 Ajax を使用してリストと 2 番目のドロップダウン メニュー オプションの無限ロードを実現する(コードが添付されています) 🎜🎜🎜

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

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