一、从前端向后端传送数据
常见的3种方式
1、form表单的action:此方法可以提交form表单内的输入数据,也可同时提交某些隐藏但设置有默认值的<input>,如修改问题时,我们除了提交问题的相关信息,还需要将用户的编号提交给后端,此时就可以设置一个默认值为用户编号的<input>,并将其隐藏
2、<a>标签的href属性:此方法一般用来提交一些较少的数据,比如对象编号
1 <a href="<%=path%>/Question/DisplayQuestionInfo?question_id=${question.question_id}" rel="external nofollow" >${question.question_title}</a>
比如该处代码,显示了问题的标题信息,并将其作为超链接,点击该链接时进入后端Controller类的方法,并向其发送问题编号question_id
3、ajax请求:此方法一般在不需要页面跳转时采用,可以局部刷新页面,比如向后端提交关注某用户的信息,后端收到ajax的请求数据,对数据库进行操作,并通过@Response注解返回信息给前端,然后前端进行相关操作,可以不进行页面跳转
前端部分代码
<script language="JavaScript"> ...... function SaveUserFollowUser(){ var login_user_id = ${login_user_id} //登录者(发起者)编号 var user_id = ${user.user_id}; //接受者用户编号 $.ajax({ url:"<%=path%>/UserRelation/SaveUserFollowUser", type:"POST", async: false, contentType:"application/json;charset=UTF-8", dataType:'json', data:JSON.stringify({"from_user_id":login_user_id,"to_user_id":user_id}), //JSON对象转为字符串 success:function(data){ /* 可在后端增加判断发起者和接受者用户是否是同一用户的判断 */ if (data == true) { alert("关注成功"); } else { alert("您已经关注该用户,不可重复关注") } } }); } </script> ...... <button class="btn btn-success" style="width: 100px" onclick="SaveUserFollowUser()">关注用户</button> ......
后端Controller类
/** * 表现层 用户关系相关 (关注用户、被用户关注、关注问题、赞同回答) */ @Controller @RequestMapping("/UserRelation") public class UserRelationController { ...... /** * 新增某用户关注某用户 * @param map * @return */ @RequestMapping(value = "/SaveUserFollowUser",method = {RequestMethod.POST}) public @ResponseBody Boolean SaveUserFollowUser(@RequestBody Map<String,String> map) { //关注发出者编号 Integer from_user_id = Integer.parseInt(map.get("from_user_id")); //关注接受者编号 Integer to_user_id = Integer.parseInt(map.get("to_user_id")); //是否新增成功 //该项可以增加发起者用户和接受者用户是否是同一用户的判断,即比较from_user_id与to_user_id是否相等,如果相等则关注失败 //通过返回Integer类型而非Boolean类型的做判断 本程序并未增加这项判断 Boolean flag = userRelationService.saveUserFollowUser(from_user_id,to_user_id); return flag; } ...... }
二、从后端向前端传送数据
1、Model
后端部分代码
/** * 表现层 用户 */ @Controller @RequestMapping(value = "/User") public class UserController { ...... /** * 进入个人信息页面 * @param httpSession * @param model * @return */ @RequestMapping(value = "/DisplayMyInfo") public String DisplayMyInfo(HttpSession httpSession, Model model) { Integer user_id = (Integer) httpSession.getAttribute("login_user_id"); //登录者个人编号 User user = userService.findUserById(user_id); //登录者个人信息 model.addAttribute("user",user); //将登录者个人信息返回给前端 return "User/myInfo"; } ...... }
前端部分代码
...... <div class="col-md-6 col-md-offset-5" style="text-align: left;"> <h2>用户名:${user.user_name}</h2> <h2>用户昵称:${user.user_nickname}</h2> <h2>用户性别:${user.user_sex}</h2> <h2>用户邮箱:${user.user_email}</h2> <h2>用户密码:${user.user_password}</h2> </div> ......
此时可以通过${}直接取得后端传来的数据
2、ModelAndView
该方法与Model相比,多增加了返回的视图(View),对于返回给前端的具体数据处理类似
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍利用Node.js+Koa框架实现前后端交互的方法,包括了利用Node.js+Koa框架实现前后端交互的方法的使用技巧和注意事项,需要的朋友参考一下 前言 对于一个前端工程师来说不仅仅要会前端的内容,后端的技术也需要熟练掌握。今天我就要通过一个案例来描述一下前端是如何和后端进行数据交互的。 koa 是由 Express 原班人马打造的,致力于成为一个更小、更富有表现力、更健壮的 We
本文向大家介绍UnityWebRequest前后端交互实现过程解析,包括了UnityWebRequest前后端交互实现过程解析的使用技巧和注意事项,需要的朋友参考一下 一、技术概述 1、描述这个技术是做什么? 是Unity一套网络工具库,用于进行Http请求 2、学习该技术的原因? 项目需要,防止使用C#原生的网络库,加快开发速度 3、技术的难点在哪里 Unity仅提供了基础的功能,如何把这些功能
本文向大家介绍ASP.NET使用AjaxPro实现前端跟后台交互详解,包括了ASP.NET使用AjaxPro实现前端跟后台交互详解的使用技巧和注意事项,需要的朋友参考一下 使用 AjaxPro 进行交互,很多人都写过文章了,为什么还要继续老生常谈呢。因为有一些细节上的东西我们需要注意,因为这些细节如果不注意的话,那么程序会报错,而且维护性较差。 引言 一.首先,还是那句话,欲练神功,必先自宫。我们
本文向大家介绍ssm框架Springmvc文件上传实现代码详解,包括了ssm框架Springmvc文件上传实现代码详解的使用技巧和注意事项,需要的朋友参考一下 一、上传: 1)编写前台文件上传表单。Method必须为post,enctype为mutipart/form-data 2)编写控制层代码,获取上传的文件数据,并保存MultipartFile; 3)在springmvc配置文件中配置文件上
本文向大家介绍Ajax 框架之SSM整合框架实现ajax校验,包括了Ajax 框架之SSM整合框架实现ajax校验的使用技巧和注意事项,需要的朋友参考一下 刚学习了ssm框架,ajax校验成功,分享下 1.导入jar包 2.配置spring-servlet.xml 3.控制器中用@ResponseBody实现返回json数据格式 4.页面中接收查询到的结果 实现结果就是以下这样的: 以上所述是小编
本文向大家介绍实现前后端数据交互方法汇总,包括了实现前后端数据交互方法汇总的使用技巧和注意事项,需要的朋友参考一下 此文章适合前后端协同开发经验不足的新手阅读。 HTML赋值 输出到 Element 的 value 或 data-name 渲染结果 使用 JS 获取 优点: 不占用全局变量,由 JS 自由获取。 使用建议: 适合传递简单数据,也非常适合多个简单数据与 Element 绑定关系。 J