前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ajax提交JSON数组及Springboot接收转换为list类

ajax提交JSON数组及Springboot接收转换为list类

作者头像
程裕强
发布2019-07-02 10:51:20
3.8K0
发布2019-07-02 10:51:20
举报

版权声明:本文为博主原创文章,欢迎转载。 https://cloud.tencent.com/developer/article/1454281

1、AJAX传递JSON数据

代码语言:javascript
复制
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<script type="text/javascript" src="/bloomberg/js/jquery-3.3.1.js"></script>
<script type="text/javascript" th:inline="javascript">
    function save() {
        var data = JSON.stringify({d_date: "2019-06-06",vc_exchange : "IB",vc_symbol:"038007",
                                    vc_symbol_id:"038007.IB",vc_name:"03中铁债",vc_type:"KRD",
                                    vc_type_detail:"KRD_3MO",f_value:"0.009399",vc_source:"test",d_updatetime:"2019-06-06 11:11:28"})
        $.ajax({
            type : "post",
            url : "/bloomberg/save",
            data : data,
            contentType: 'application/json',
            success : function (result) {
                console.log(result);
            }
        })
    };
    save();
</script>

<body>

</body>
</html>
代码语言:javascript
复制
    @RequestMapping(value="/save",method = RequestMethod.POST,consumes = "application/json")
    @ResponseBody
    public String save(@RequestBody XxxBean bean){
        System.out.println(bean);
        return "success";
    }

2、AJAX传递JSON数组

代码语言:javascript
复制
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<script type="text/javascript" src="/bloomberg/js/jquery-3.3.1.js"></script>
<script type="text/javascript" th:inline="javascript">
    function saveAll() {
        var data = [
            {
                 d_date: "2019-06-06",vc_exchange : "IB",vc_symbol:"038007",
                 vc_symbol_id:"038007.IB",vc_name:"03中铁债",vc_type:"KRD",
                 vc_type_detail:"KRD_3MO",f_value:"0.009399",vc_source:"Bloomberg",d_updatetime:"2019-06-06 11:11:28"
            }, {
                d_date: "2019-06-05",vc_exchange : "IB",vc_symbol:"058028",
                vc_symbol_id:"058028.IB",vc_name:"05中远债2",vc_type:"KRD",
                vc_type_detail:"KRD_9YR",f_value:"0.000000",vc_source:"test",d_updatetime:"2019-06-05 14:08:40"
            }];
        $.ajax({
            type : "post",
            url : "/bloomberg/saveAll",
            data : JSON.stringify({beans:data}),
            contentType: 'application/json',
            success : function (result) {
                console.log(result);
            }
        })
    };
    saveAll();
</script>

<body>

</body>
</html>

不能直接使用JSONArray类型的参数接收前台的json数组字符串。曲线救国:用JSONObject接收,然后取出JSONArray。

代码语言:javascript
复制
    @RequestMapping(value="/saveAll",method = RequestMethod.POST,consumes = "application/json")
    @ResponseBody
    public String saveAll(@RequestBody JSONObject jsonObject){
        JSONArray jsonArray = jsonObject.getJSONArray("beans");
        List<XxxBean> list=(List)JSONArray.toCollection(jsonArray,XxxBean.class);
        xxxService.saveAll(list);
        return "successAll";
    }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年06月10日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、AJAX传递JSON数据
  • 2、AJAX传递JSON数组
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档