Ajax를 사용하여 배열을 전달하고 백그라운드에서 수신하는 방법에 대한 자세한 설명

亚连
풀어 주다: 2018-05-22 11:52:26
원래의
3938명이 탐색했습니다.

이 기사에서는 Ajax를 사용하여 백그라운드에서 배열을 전송하고 수신하는 방법에 대한 관련 정보를 주로 소개합니다. 기사의 소개는 매우 자세하며 필요한 모든 친구가 함께 와서 배울 수 있는 특정 참고 자료와 학습 가치가 있습니다.

머리말

Ajax를 사용하여 다중 선택 상자를 비동기적으로 제출하여 작업해야 하는 개체의 ID를 가져옵니다. 이때 각 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() </code >json 배열을 가져오고 루프를 통해 원하는 속성을 구문 분석합니다. </p><p></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:js;">&lt;span style=&quot;font-family:SimSun;font-size: 10.5pt;&quot;&gt; &lt;/span&gt;&lt;span style=&quot;font-family:KaiTi_GB2312;font-size:14px;&quot;&gt; @RequestMapping(&quot;selectdelbooks&quot;) public String selectdelbooks(HttpServletRequest request) throws Exception { ServletInputStream inputStream = request.getInputStream(); String mybooksid = IOUtils.toString(inputStream); JSONArray jsonarr = new JSONArray(mybooksid); List&lt;String&gt; book_id =new ArrayList&lt;String&gt;(); for (int i=0;i&lt;jsonarr.length();i++){ book_id.add(((JSONObject)jsonarr.get(i)).getString(&quot;book_id&quot;)); }...&lt;/span&gt;</pre><div class="contentsignin">로그인 후 복사</div></div><p class="jb51code"></p> <p>위 js에서 선택한 각 ID를 mysendbook_id의 "book_id" 속성에 넣은 다음 이 개체를 booksid를 배열로, 비동기 요청을 보낼 때 </p> <p></p> <code>JSON.stringify(bookid)를 사용하여 booksid 배열의 형식을 지정하고 json 배열을 가져옵니다.

백그라운드에서 어떻게 수신되는지 살펴보겠습니다.

첫 번째는 목록으로 클래스를 만드는 것입니다. 이 목록에는 bookid에 대한 속성이 하나만 있는 클래스가 포함되어 있으며 주석 @을 사용합니다. RequestBody 이 형식 매개변수에 추가하세요. 하지만 이것이 더 문제가 됩니다.

또 다른 방법은 입력 스트림에서 데이터를 가져오고 IOUtils.toString 을 사용하여 inputStream을 문자열로 변환한 다음 new JSONArray(mybooksid)를 사용하는 것입니다. ; code>각 json

rrreee

에서 book_id 속성 값을 가져오려면 이 json 배열

을 가져옵니다. 이런 식으로 우리는 선택한 id 값이 포함된 목록을 얻습니다.

데이터베이스 정보:


페이지에서 다중 선택:


백그라운드에서 얻은 선택한 책의 ID:


이런 방식으로 ID 세트는 얻어지고 후속 작업이 편리해집니다.

위 내용은 모두를 위해 제가 정리한 내용입니다. 앞으로 모든 사람에게 도움이 되기를 바랍니다. 관련 기사:

🎜🎜Ajax가 특수 문자를 사용하여 데이터를 전달하는 문제를 해결하는 방법🎜🎜🎜🎜🎜로컬(파일 프로토콜) AJAX 요청을 지원하도록 Chrome 구성(그래픽 튜토리얼) 🎜🎜🎜🎜🎜 AJAX 페이징의 간단한 구현 효과(그래픽 및 텍스트) 튜토리얼)🎜🎜🎜🎜🎜🎜🎜🎜🎜

위 내용은 Ajax를 사용하여 배열을 전달하고 백그라운드에서 수신하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!