springmvc前后端传值总结
1 前端向后端传参
1.1 普通方式传参
1.1.1 页面
参数需要解析成json对象;JSON.parse(JSON.stringify(query))
|
$.getJSON("${serverUrl}/store/brand/getBrand", JSON.parse(JSON.stringify(query)), function(data){}); |
1.1.2 后端
使用普通的参数即可,不需要配置
|
@RequestMapping("/getBrand") @ResponseBody public WebResponse<Page<BrandVo>> getBrand(BrandQuery query, Pageable pageable) { WebResponse<Page<BrandVo>> response = new WebResponse<Page<BrandVo>>(); // set storeid query.setStoreid(1L); response.setData(brandService.getStoreBrandByCondition(query, pageable)); return response; } |
1.2 json对象传参
1.2.1 页面
需要定义contentType: "application/json; charset=utf-8";
参数需转换成字符串;data : JSON.stringify(brandSaveInfo)
|
$.ajax({ url : "${serverUrl}/store/brand/addBrandDetail", type : "POST", datatype:"json", contentType: "application/json; charset=utf-8", data : JSON.stringify(brandSaveInfo), success : function(data, stats) { console.log("保存成功:"+stats); }, error : function(data) { } }); |
1.2.2 后端
参数定义前需加上@RequestBody
|
@RequestMapping("/addBrandDetail") @ResponseBody public WebResponse<String> addBrandDetail(@Valid @RequestBody BrandDetailVo brandDetailVo, BindingResult bindingResult) { if (bindingResult.hasErrors()) { throw new NovaIllegalArgumentException(bindingResult); } WebResponse<String> response = new WebResponse<String>(); // 从shiro得到uid Long storeid = 1L; brandService.addBrandDetail(brandDetailVo, storeid); response.setData(NovaConstants.APPLICATION_SUCCESS); return response; } |
1.3 简单对象、复杂对象
简单对象是指基本类型、基本类型数组、自定义对象;
复杂对象是指自定义对象数组;
复杂对象只能通过json对象传参,简单对象可以使用两种方式传参;
使用普通方式传参还是json方式传参,与get/post请求方式无关,只与参数对象的复杂程度有关(是简单对象还是复杂对象)。
1.4 日期类型参数
前端参数使用字符串
在普通方式传参方式,后台需要设置DateTimeFormat
|
@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date upperSaleTime;//上架时间or下架时间上限 |
在json对象传参,后台需要设置dateDeSerialize
|
@JsonDeSerialize(using=DateDeSerializer.class) private Date saleTime; // 上架或下架时间 |
2 后台返回页面数据
后台返回数据有两种方式:json数据、页面数据
2.1 json数据
使用@responsebody
2.2 页面数据
返回ModelAndView
2.3 日期类型
返回json数据时,日期类型需要设置为dateSerialize
|
@JsonSerialize(using=DateSerializer.class) private Date saleTime; // 上架或下架时间 |
springmvc前后端传值总结的更多相关文章
- springmvc前后端传值
@pathvible 后端传值(rest风格) exp: @requestMapping("/view/{userId}") public String getiew(@Parth ...
- Thymeleaf前后端传值 页面取值与js取值
参考: Thymeleaf前后端传值 页面取值与js取值 Thymeleaf 与 Javascript Thymeleaf教程 (十二) 标签内,js中使用表达式 目的: 后端通过Model传值到前端 ...
- content-type常见类型辨析(以ajax与springmvc前后端交互为例)
博客搬家: content-type常见类型辨析(以ajax与springmvc前后端交互为例) 在http报文的首部中,有一个字段Content-type,表示请求体(entity body)中的数 ...
- SpringMVC踩坑3——前后端传值问题
在前端页面点击修改,同时把需要修改的ID传到后端,后端根据ID去修改具体数据 这是前端代码 <a href="${pageContext.request.contextPath}/bo ...
- SpringMVC前后端数据交互总结
控制器 作为控制器,大体的作用是作为V端的数据接收并且交给M层去处理,然后负责管理V的跳转.SpringMVC的作用不外乎就是如此,主要分为:接收表单或者请求的值,定义过滤器,跳转页面:其实就是ser ...
- SpringMVC前后端分离交互传参详细教程
温故而知新,本文为一时兴起写出,如有错误还请指正 本文后台基于SpringBoot2.5.6编写,前端基于Vue2 + axios和微信小程序JS版分别编写进行联调测试,用于理解前后端分离式开发的交互 ...
- mui与springMVC前后端分离
这个小dome简单来说的前后端分离,通过跨域调用接口来显示数据. 前端用到mui框架,主要来显示数据. 后端用到Java的springMVC,restful服务来做增删改查管理, 这里主要实现动态显示 ...
- JQuery ajax 前后端传值介绍
https://jingyan.baidu.com/album/ca41422f0bf08e1eae99ed04.html?picindex=5 现在我们话不多说,开始仔细讲解一下我们ajax内部传递 ...
- SpringMVC前后端参数交互
Controller中使用JSON方式有多种 关键在于ajax请求是将数据以什么形式传递到后台 HTTP请求中: 如果是get请求,那么表单参数以name=value&name1=value1 ...
随机推荐
- 创建本地CM 离线服务器
一.包管理工具及CentOS的yum 1.包管理工具如何发现可以用的包 包管理工具依赖一系列软件源,工具下载源的信息存储在配置文件中,其位置随某包管理工具不同而变化 使用yum的RedHat/Cent ...
- Django ORM 中的批量操作
Django ORM 中的批量操作 在Hibenate中,通过批量提交SQL操作,部分地实现了数据库的批量操作.但在Django的ORM中的批量操作却要完美得多,真是一个惊喜. 数据模型定义 首先,定 ...
- hdoj 3790 最短路径问题
最短路径问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- (step 4.3.5)hdu 1035(Robot Motion——DFS)
题目大意:输入三个整数n,m,k,分别表示在接下来有一个n行m列的地图.一个机器人从第一行的第k列进入.问机器人经过多少步才能出来.如果出现了循环 则输出循环的步数 解题思路:DFS 代码如下(有详细 ...
- UVa 10465 Homer Simpson (枚举)
10465 - Homer Simpson Time limit: 3.000 seconds http://uva.onlinejudge.org/index.php?option=com_onli ...
- HDU 3635 并查集+路径压缩+记录每个点移动次数
题意: 给定n个点 oper个操作 每个点有1个龙珠 下面2种操作: T u v 把u点所有龙珠搬到v Q u 问u点当前所在城市 u点所在城市有几个龙珠 u点被移动几次 思路: 并查集可以求出 u ...
- 单点登录系统CAS筹建及取得更多用户信息的实现
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- 看文章《EAI和SOA的比较》有感(1)
<EAI和SOA的比较>http://www.cnblogs.com/asdling/archive/2007/11/26/973100.html这篇文章写的很全面,至少自己这么认为,也解 ...
- Windows Server 2008找回密码
1.通过Windows Server 2008 R2的安装光盘引导计算机启动,映像加载完毕后 ,按 Shift+F10 ,打开命令提示符界面,进入Windows目录所在分区(cd windows\sy ...
- Zmodem transfer canceled by remote side
linux sz命令时报这个错误,看了一头雾水. 仔细看了一下发现竟然是要sz的文件名称写错了,抱着个错误和误导人呢.估计路径写错了也是这个错误.