前后台交互经常使用的技术汇总(后台:Java技术,前台:Js或者Jquery)

简介: 1:由于针对特定的前后台交互用到的知识总结,所以不大量贴代码,主要给出思路,方便自己以后脑补和技术总结,当然也希望可以帮助到别人。 后台Json和其他格式转化,之前总结过Json和对象,集合,字符串的转化或者互相转化,这里我想网上有很多demo。

1:由于针对特定的前后台交互用到的知识总结,所以不大量贴代码,主要给出思路,方便自己以后脑补和技术总结,当然也希望可以帮助到别人。

后台Json和其他格式转化之前总结过Json和对象,集合,字符串的转化或者互相转化,这里我想网上有很多demo。

servlet,或者strtus2或者SpringMvc,在控制层将传递到前台的数据进行封装或者转化为Json,对你的开发十分有帮助。

  案例一:当前台申请或者取消按钮的时候,前台根据操作显示对应的提示,非弹出框。

(1):此处使用SpringMvc作为Controller层。

 1 @RequestMapping(value="/applyRights")
 2          protected void applyRights(final HttpServletRequest request, final HttpServletResponse response) throws Exception{
 3          
 4             ...操作
 5             ...操作
 6             ...操作
 7             ...操作
 8          Map<String,Object> map = new HashMap<String,Object>();
 9          //这里将前台的两种操作返回的数据分别,保存到map里面。
10          map.put("返回的数据1", 返回的数据1);
11          map.put("返回的数据2", 返回的数据2);
12          //然后使用JsonUtil,这个封装好的Json转化工具类,将map类型转化为Json类型的。Java的map集合类型转化为Json类型。
13          String json = JOSNUtil.object2String(map);
14          //将转化后的数据传递给前台的Ajax的function(data){}的data.
15          response.getWriter().write(json);  
16          //刷新操作
17          response.getWriter().flush();

(2):前台使用Jquery进行后台数据处理:Jquery速查网址

 1 function 方法名称(参数){
 2             ...操作
 3             ...操作
 4             ...操作
 5             //$.post的用法自行查阅
 6             $.post(
 7                 url:发送请求地址,
 8                 data:待发送 Key/value 参数,
 9                 function(data){
10                     //alert(data);//可以打印传过来的参数
11                     //解析后台传过来的map转成的json格式的字符,Java的map集合类型转化为Json类型。
12                     //eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。
13                     var json = eval("(" + data + ")");
14                     //直接使用json.key的形式进行获取
15                     if(json.返回的数据1!=null){
16                         //js循环遍历返回的值,注我的map的value是数组类型的(Object)。
17                          for(var i=0;i< json.返回的数据1.length;i++){
18                                 //获取到这个id是为了动态根据某一个角色id来追加内容。
19                                 var roleId = json.返回的数据1[i];
20                                 //动态根据某一个角色id来追加内容。"#"+roleId代表选择器动态变化。
21                                 $("#"+roleId).append('<span style="color:red;">(申请权限待审批)</span>');
22                                 //此句话的,查找每个动态id元素的所有类名为 "selected" 的所有同胞元素:
23                                 //然后attr() 方法设置或返回被选元素的属性值。
24                                 //然后设置一下checkbox为不选中,且disabled不可选。
25                                 $("#"+roleId).siblings().attr("checked",false).attr("disabled",true);
26                              }
27                     }
28                     //同上
29                     if(json.返回的数据2!=null){
30                         for(var i=0;i< json.返回的数据2.length;i++){
31                              var roleId= json.返回的数据2[i]
32                              $("#"+roleId).append('<span style="color:red;">(申请注销待审批)</span>');
33                              $("#"+roleId).siblings().attr("checked",false).attr("disabled",true);                    
34                          }
35                     }
36             });
37 
38         }

  案例一:根据id动态变化传递到后台,ajax异步请求,刷新前台显示内容。

(1):此处使用SpringMvc作为Controller层。

 1 //根据角色id获取资源信息/index/getResource
 2         //@ResponseBody将返回值转化为json格式响应到客户端
 3         @RequestMapping(value="/getResource",method=RequestMethod.POST)
 4         public @ResponseBody List<Object> roleGetResource(HttpServletRequest request, HttpServletResponse response) 
 5             throws Exception{
 6         //设置编码格式
 7         response.setCharacterEncoding("utf-8");
 8         
 9         //获取到角色的编号
10         String roleId = request.getParameter("roleId");
11         
12         //开始根据角色的编号查询其下的权限资源
13         List<Map<String, Object>> resourcebyRole = bizUser.getResourcebyRole(roleId);
14         
15         List<Object> list = new LinkedList<Object>();
16         Iterator<Map<String, Object>> it = resourcebyRole.iterator();
17         //只获取到资源的名称,返回到前台即可
18         while(it.hasNext()){
19             Map<String, Object> resMap = it.next();
20             Object object = resMap.get("RES_NAME");
21             
22             list.add(object);
23         }
24         //将资源的名称传递到前台的function(data){}的data.
25         return list;
26     }

 (2):前台使用Jquery进行后台数据处理:Jquery速查网址

 1 $(document).ready(function(){
 2             var roleId = null;
 3             //获取到所有的角色RoleId
 4             $(".roleId").each(function(){
 5                 //当鼠标移动到角色名称,触发事件,鼠标移入效果
 6                 $(this).mouseover(function(){
 7                 //鼠标点击效果,触发事件,鼠标移入效果
 8                 //$(this).click(function(){
 9                      //此句话获取到该span的id属性的值。
10                      roleId = $(this).attr("id");
11                      //alert(roleId);
12                      //调用ajax异步请求,获取角色下面的资源
13                      $.ajax({
14                          type : "POST",//post类型请求。
15                          data : {"roleId":roleId},//将每一次获取到角色id传递到后台。
16                          url : "../right/getResource",//请求后台的路径
17                          success : function(resourceByRole) {//参数即后台返回的数据。
18                             //alert(resourceByRole);//先测试一下返回的数据是否正确
19                             //判断是否为空或者为null
20                              if(resourceByRole == null || resourceByRole == ""){
21                                 //然后根据div的class属性进行追加或者显示内容即可。
22                                  $(".resourceShow").html('<span style="color:red;">此角色下面没有权限</span>');
23                              }else{
24                                 //
25                                  $(".resourceShow").text(resourceByRole);
26                              }
27                          },
28                      });
29                 })
30             });
31         });  

 待续......

目录
相关文章
|
15天前
|
监控 Cloud Native Java
Quarkus 云原生Java框架技术详解与实践指南
本文档全面介绍 Quarkus 框架的核心概念、架构特性和实践应用。作为新一代的云原生 Java 框架,Quarkus 旨在为 OpenJDK HotSpot 和 GraalVM 量身定制,显著提升 Java 在容器化环境中的运行效率。本文将深入探讨其响应式编程模型、原生编译能力、扩展机制以及与微服务架构的深度集成,帮助开发者构建高效、轻量的云原生应用。
109 44
|
9天前
|
安全 Java API
Java Web 在线商城项目最新技术实操指南帮助开发者高效完成商城项目开发
本项目基于Spring Boot 3.2与Vue 3构建现代化在线商城,涵盖技术选型、核心功能实现、安全控制与容器化部署,助开发者掌握最新Java Web全栈开发实践。
92 1
|
30天前
|
安全 Java 编译器
new出来的对象,不一定在堆上?聊聊Java虚拟机的优化技术:逃逸分析
逃逸分析是一种静态程序分析技术,用于判断对象的可见性与生命周期。它帮助即时编译器优化内存使用、降低同步开销。根据对象是否逃逸出方法或线程,分析结果分为未逃逸、方法逃逸和线程逃逸三种。基于分析结果,编译器可进行同步锁消除、标量替换和栈上分配等优化,从而提升程序性能。尽管逃逸分析计算复杂度较高,但其在热点代码中的应用为Java虚拟机带来了显著的优化效果。
51 4
|
1月前
|
Java API Maven
2025 Java 零基础到实战最新技术实操全攻略与学习指南
本教程涵盖Java从零基础到实战的全流程,基于2025年最新技术栈,包括JDK 21、IntelliJ IDEA 2025.1、Spring Boot 3.x、Maven 4及Docker容器化部署,帮助开发者快速掌握现代Java开发技能。
359 1
|
29天前
|
Java 测试技术 API
2025 年 Java 开发者必知的最新技术实操指南全览
本指南涵盖Java 21+核心实操,详解虚拟线程、Spring Boot 3.3+GraalVM、Jakarta EE 10+MicroProfile 6微服务开发,并提供现代Java开发最佳实践,助力开发者高效构建高性能应用。
262 4
|
9天前
|
安全 Cloud Native Java
Java 模块化系统(JPMS)技术详解与实践指南
本文档全面介绍 Java 平台模块系统(JPMS)的核心概念、架构设计和实践应用。作为 Java 9 引入的最重要特性之一,JPMS 为 Java 应用程序提供了强大的模块化支持,解决了长期存在的 JAR 地狱问题,并改善了应用的安全性和可维护性。本文将深入探讨模块声明、模块路径、访问控制、服务绑定等核心机制,帮助开发者构建更加健壮和可维护的 Java 应用。
71 0
|
1月前
|
JavaScript 安全 前端开发
Java开发:最新技术驱动的病人挂号系统实操指南与全流程操作技巧汇总
本文介绍基于Spring Boot 3.x、Vue 3等最新技术构建现代化病人挂号系统,涵盖技术选型、核心功能实现与部署方案,助力开发者快速搭建高效、安全的医疗挂号平台。
131 3
|
1月前
|
存储 人工智能 算法
Java 大视界 -- Java 大数据在智能医疗影像数据压缩与传输优化中的技术应用(227)
本文探讨 Java 大数据在智能医疗影像压缩与传输中的关键技术应用,分析其如何解决医疗影像数据存储、传输与压缩三大难题,并结合实际案例展示技术落地效果。
|
1月前
|
机器学习/深度学习 算法 Java
Java 大视界 -- Java 大数据在智能物流运输车辆智能调度与路径优化中的技术实现(218)
本文深入探讨了Java大数据技术在智能物流运输中车辆调度与路径优化的应用。通过遗传算法实现车辆资源的智能调度,结合实时路况数据和强化学习算法进行动态路径优化,有效提升了物流效率与客户满意度。以京东物流和顺丰速运的实际案例为支撑,展示了Java大数据在解决行业痛点问题中的强大能力,为物流行业的智能化转型提供了切实可行的技术方案。
|
1月前
|
分布式计算 Cloud Native 安全
Java:历久弥新的技术基石
Java:历久弥新的技术基石