使用Jquery $ .ajax将json数据传递到servlet(doPost)

杰姆赫兹

我正在学习有关对ajax的调用,因此我试图获取('#abcd')(一个html选择)的值。我正在使用以下行:

abcdVal = combo.options [combo.selectedIndex] .value

当此值更改时,我必须将其值存储在类似abcdVal的变量中,以便通过以下方式传递给servlet:

var data = {“ text”:abcdVal};

j("#mybutton").click(function(){    
    j.ajax({method: 'POST',
        url: "/bin/company/repo",
        dataType: 'JSON',
        data: data, 
        success:function(result){
            alert(result);
            j("#demo").html('');
            j('#demo').html(result);
        }});
});

我得到了值并将响应作为纯文本形式输入,但是在html页面中,我看到了:

[{“ text”:null,“ value”:10}]

代替[{“ text” :( html select的选定值),“ value”:10}]

我做错了什么,然后将数据传递给servlet。我该如何正确通过此变量?


我的密码

JavaScript代码

<script type="text/javascript">
var j = jQuery.noConflict();
var abcdVal;
j(document).ready(function(){
   //get a reference to the select element
  //request the JSON data and parse into the select element
  j.ajax({
      url: '/bin/company/repo',
      dataType:'JSON',
      success:function(data){
        //clear the current content of the select
        j('#abcd').html('');
        //iterate over the data and append a select option
        jQuery.each(data, function(text, value){
            j('#abcd').append('<option id="' + value.value + '">' +         value.text + '</option>');
        });
      },
      error:function(){
        //if there is an error append a 'none available' option
        j('#abcd').html('<option id="-1">none available</option>');
      }
});
j("#abcd").change(function(){
    var combo = document.getElementById('abcd');
    if(combo.selectedIndex<0)
        alert('No hay opcion seleccionada');
    else 
        abcdVal = combo.options[combo.selectedIndex].value;
        alert('La opcion seleccionada es: '+combo.options[combo.selectedIndex].value);
});
var data = {"text" : abcdVal};
alert(data);
j("#mybutton").click(function(){    
    j.ajax({method: 'POST',
        url: "/bin/company/repo",
        dataType: 'JSON',
        data: data, 
        success:function(result){
            alert(result);
            j("#demo").html('');
            j('#demo').html(result);
        }});
});
})
</script>

Servlet代码

@Override
protected void doPost(SlingHttpServletRequest request, SlingHttpServletResponse response) throws ServletException,
        IOException {
        String text = (String) request.getParameter("text");
        response.setHeader("Content-Type", "text/html; charset=UTF-8");
        StringWriter writer = new StringWriter();
        TidyJSONWriter json = new TidyJSONWriter(writer); 
        try 
        {   
           json.array();
           //loop through your options and create objects as shown below 
           json.object();
           json.key("text");
           json.value(text);
           json.key("value");
           json.value(10);
           json.endObject();
           //end your array 
           json.endArray();     
        } catch(JSONException e) {
            e.printStackTrace();
        }

       response.getWriter().write(writer.toString());      // Write response body.  
}
杰姆赫兹

我做了这些更改以解决我的问题:

1)在ajax调用更改方法中:通过类型:“ POST”进行POST。

2)默认情况下,在调用ajax之前添加even.preventDefault(),不要使用提交。

3)更改我处理数据请求的形式。如果我不通过表格,我需要这样做以获取请求参数,例如@Sabya说明。

4)处理成功内的json(ajax)以进行html select的显示选择。

所以代码是下一个:

的JavaScript

<script type="text/javascript">
var j = jQuery.noConflict();
var abcd = document.getElementById("abcd");
var selection = abcd.options[abcd.selectedIndex].value
j(document).ready(function(){
   j.ajax({
          url: '/bin/company/repo',
          dataType:'JSON',
          success:function(data){
             jQuery.each(data, function(text, value){
             j('#abcd').append('<option id="' + value.value + '">' + value.text + '</option>');
        });
      },
      error:function(){
        //if there is an error append a 'none available' option
        j('#abcd').html('<option id="-1">none available</option>');
      }
   });
   j("#abcd").live('change',function(){
      var combo = document.getElementById('abcd');
      if(combo.selectedIndex<0)
        alert('no option selected');
      else 
        selection = combo.options[combo.selectedIndex].value;
   });

   j('form').on('submit', function(e){
      event.preventDefault();
      j.ajax({type: 'POST',
         contentType: "application/json; charset=utf-8",
         url: "/bin/company/repo",
         dataType: 'JSON',
         data: JSON.stringify({ "text": selection }), 
         success:function(data){
            jQuery.each(data, function(text, value){
                 j('#demo').html('');
                 j('#demo').html(value.text);
            });
         }}); 
   });
})
</script>

小服务程序

@Override
protected void doPost(SlingHttpServletRequest request,       SlingHttpServletResponse response) throws ServletException,
        IOException {
        response.setHeader("Content-Type", "application/json");
        PrintWriter out = response.getWriter();
        StringWriter writer = new StringWriter();
        TidyJSONWriter json = new TidyJSONWriter(writer); 
        StringBuilder buffer = new StringBuilder();
        BufferedReader reader = request.getReader();
        String line;
        while ((line = reader.readLine()) != null) {
            buffer.append(line);
        }
        String data = buffer.toString();
        try 
        {   
           JSONObject jsonObj = new JSONObject(new String(data));
           json.array();
           //loop through your options and create objects as shown below 
           json.object();
           json.key("text");
           json.value(jsonObj.get("text"));
           json.endObject();
           //end your array 
           json.endArray();
        } catch(JSONException e) {
            e.printStackTrace();
        }
        out.write(writer.toString());

}

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

使用Jquery $ .ajax将json数据传递到servlet(doPost)

来自分类Dev

使用Extjs将表单数据传递到servlet

来自分类Dev

使用Extjs将表单数据传递到servlet

来自分类Dev

如何使用ajax发布将JSON数据传递到php

来自分类Dev

如何使用Codeigniter将数据传递到Ajax中?

来自分类Dev

如何使用Codeigniter将数据传递到Ajax中?

来自分类Dev

使用 JQuery 一次将 JSON 数据传递到 div 中

来自分类Dev

如何使用 Ajax 将 Json 数组从 JSP 传递到 Servlet

来自分类Dev

jQuery将数据传递到MVC4中的Ajax函数

来自分类Dev

通过Jquery Ajax POST请求将数据传递到Postgresql DB

来自分类Dev

使用AJAX将动态数据传递到MVC控制器

来自分类Dev

使用$ .ajax(MVC 4)将数据传递到控制器

来自分类Dev

使用ajax将数据传递到bootsrap modal时为空白

来自分类Dev

使用Ajax将表单数据传递到控制器方法

来自分类Dev

使用PHP将数据传递到数据库

来自分类Dev

使用Swift + Alamofire + Swifty-Json将动态数据传递到UIScrollView

来自分类Dev

使用FastAPI将JSON数据传递到服务器的简约方法

来自分类Dev

Android使用POST方法将JSON数据传递到服务器

来自分类Dev

Ajax JQuery将数据传递给POST方法

来自分类Dev

使用DownloadManager从Activity将数据传递到BroadcastReceiver

来自分类Dev

使用Django将数据传递到Google图表

来自分类Dev

使用MVC 6 EF将数据传递到视图

来自分类Dev

使用React钩子将数据传递到同级组件?

来自分类Dev

使用DownloadManager从Activity将数据传递到BroadcastReceiver

来自分类Dev

使用kefirjs将数据传递到React组件

来自分类Dev

使用JavaScript将数据传递到模态

来自分类Dev

使用jQuery将数据传递到同一页面中的标签

来自分类Dev

PHP Foreach循环将数据传递到jquery模态以供表单使用

来自分类Dev

使用 jquery 将数据传递到新页面 $_POST

Related 相关文章

  1. 1

    使用Jquery $ .ajax将json数据传递到servlet(doPost)

  2. 2

    使用Extjs将表单数据传递到servlet

  3. 3

    使用Extjs将表单数据传递到servlet

  4. 4

    如何使用ajax发布将JSON数据传递到php

  5. 5

    如何使用Codeigniter将数据传递到Ajax中?

  6. 6

    如何使用Codeigniter将数据传递到Ajax中?

  7. 7

    使用 JQuery 一次将 JSON 数据传递到 div 中

  8. 8

    如何使用 Ajax 将 Json 数组从 JSP 传递到 Servlet

  9. 9

    jQuery将数据传递到MVC4中的Ajax函数

  10. 10

    通过Jquery Ajax POST请求将数据传递到Postgresql DB

  11. 11

    使用AJAX将动态数据传递到MVC控制器

  12. 12

    使用$ .ajax(MVC 4)将数据传递到控制器

  13. 13

    使用ajax将数据传递到bootsrap modal时为空白

  14. 14

    使用Ajax将表单数据传递到控制器方法

  15. 15

    使用PHP将数据传递到数据库

  16. 16

    使用Swift + Alamofire + Swifty-Json将动态数据传递到UIScrollView

  17. 17

    使用FastAPI将JSON数据传递到服务器的简约方法

  18. 18

    Android使用POST方法将JSON数据传递到服务器

  19. 19

    Ajax JQuery将数据传递给POST方法

  20. 20

    使用DownloadManager从Activity将数据传递到BroadcastReceiver

  21. 21

    使用Django将数据传递到Google图表

  22. 22

    使用MVC 6 EF将数据传递到视图

  23. 23

    使用React钩子将数据传递到同级组件?

  24. 24

    使用DownloadManager从Activity将数据传递到BroadcastReceiver

  25. 25

    使用kefirjs将数据传递到React组件

  26. 26

    使用JavaScript将数据传递到模态

  27. 27

    使用jQuery将数据传递到同一页面中的标签

  28. 28

    PHP Foreach循环将数据传递到jquery模态以供表单使用

  29. 29

    使用 jquery 将数据传递到新页面 $_POST

热门标签

归档