前后台交互经常使用的技术汇总(后台:Java技术,前台:Js或者Jquery)-程序员宅基地

技术标签: ViewUI  java  json  javascript  

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         });  

 待续......

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_33941350/article/details/90219264

智能推荐

手把手教你安装Eclipse最新版本的详细教程 (非常详细,非常实用)_eclipse安装教程-程序员宅基地

文章浏览阅读4.4k次,点赞2次,收藏16次。写这篇文章的由来是因为后边要用这个工具,但是由于某些原因有部分小伙伴和童鞋们可能不会安装此工具,为了方便小伙伴们和童鞋们的后续学习和不打击他们的积极性,因为80%的人都是死在工具的安装这第一道门槛上,这门槛说高也不高说低也不是太低。所以就抽时间水了这一篇文章。_eclipse安装教程

分享11个web前端开发实战项目案例+源码_前端项目实战案例-程序员宅基地

文章浏览阅读4.1w次,点赞12次,收藏193次。小编为大家收集了11个web前端开发,大企业实战项目案例+5W行源码!拿走玩去吧!1)小米官网项目描述:首先选择小米官网为第一个实战案例,是因为刚开始入门,有个参考点,另外站点比较偏向目前的卡片式设计,实现常见效果。目的为学者练习编写小米官网,熟悉div+css布局。学习资料的话可以加下web前端开发学习裙:600加上610再加上151自己去群里下载下。项目技术:HTML+CSS+Div布局2)迅雷官网项目描述:此站点特效较多,所以通过练习编写次站点,学生可以更多练习CSS3的新特性过渡与动画的实_前端项目实战案例

计算质数-埃里克森筛法(间隔黄金武器)-程序员宅基地

文章浏览阅读73次。素数,不同的质数,各种各样的问题总是遇到的素数。以下我们来说一下求素数的一种比較有效的算法。就是筛法。由于这个要求得1-n区间的素数仅仅须要O(nloglogn)的时间复杂度。以下来说一下它的思路。思路:如今又1-n的数字。素数嘛就是除了1和本身之外没有其它的约数。所以有约数的都不是素数。我们从2開始往后遍历,是2的倍数的都不是素数。所以我们把他们划掉然后如...

探索Keras DCGAN:深度学习中的创新图像生成-程序员宅基地

文章浏览阅读532次,点赞9次,收藏14次。探索Keras DCGAN:深度学习中的创新图像生成项目地址:https://gitcode.com/jacobgil/keras-dcgan在数据驱动的时代,图像生成模型已经成为人工智能的一个重要领域。其中,Keras DCGAN 是一个基于 Keras 的实现,用于构建和训练 Deep Convolutional Generative Adversarial Networks(深度卷积生...

org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):_spring-could org.apache.ibatis.binding.bindingexce-程序员宅基地

文章浏览阅读116次。今天在搭建springcloud项目时,发现如上错误,顺便整理一下这个异常:1. mapper.xml的命名空间(namespace)是否跟mapper的接口路径一致<mapper namespace="com.baicun.springcloudprovider.mapper.SysUserMapper">2.mapper.xml接口名是否和mapper.java接..._spring-could org.apache.ibatis.binding.bindingexception: invalid bound state

四种高效数据库设计思想——提高查询效率_数据库为什么能提高效率-程序员宅基地

文章浏览阅读1.1k次。四种高效数据库设计思想——提高查询效率:设计数据库表结构时,我们首先要按照数据库的三大范式进行建立数据。1. 1NF每列不可拆分2. 2NF确保每个表只做一件事情3. 3NF满足2NF,消除表中的依赖传递。三大范式的出现是在上世纪70年代,由于内存资源比较昂贵,所以严格按照三大范式进行数据库设计。而如今内存变得越来越廉价,在考虑效率和内存的基础上我们可以做出最优选择以达到最高效率。_数据库为什么能提高效率

随便推点

matlab_matlab fat-程序员宅基地

文章浏览阅读94次。为什么logical==0?_matlab fat

HTML标签分类及转义字符_ol是单标记还是双标记-程序员宅基地

文章浏览阅读302次。一. HTML标签分类1.根据标签个数分类。 单标签:只有一个标签。 <br>, <hr>,<img>,<meta>, 实现一个特定的功能。 双标签:既有开始标签,也有结束标签。 Html,head,Body,title,h1~h6,p,a,ul,li,ol,strong,em。2.根据标签特性分类(网页效果)。 2.1行属性..._ol是单标记还是双标记

什么是配置_基于配置是什么意思-程序员宅基地

文章浏览阅读1.6k次。应用程序在启动和运行的时候往往需要读取一些配置信息,配置基本上伴随着应用程序的整个生命周期,比如:数 据库连接参数、启动参数等。配置主要有以下几个特点:配置是独立于程序的只读变量配置对于程序是只读的,程序通过读取配置来改变自己的行为,但是程序不应该去改变配置配置伴随应用的整个生命周期配置贯穿于应用的整个生命周期,应用在启动时通过读取配置来初始化,在运行时根据配置调整行为。比如:启动时需要读取服务的端口号、系统在运行过程中需要读取定时策略执行定时任务等。配置可以有多种加载方式常见的有程序内部_基于配置是什么意思

二、使用GObject——一个简单类的实现-程序员宅基地

文章浏览阅读170次。Glib库实现了一个非常重要的基础类--GObject,这个类中封装了许多我们在定义和实现类时经常用到的机制: 引用计数式的内存管理 对象的构造与析构 通用的属性(Property)机制 Signal的简单使用方式 很多使用GObject..._

golang 定时任务处理-程序员宅基地

文章浏览阅读6.3k次,点赞2次,收藏9次。在 golang 中若写定时脚本,有两种实现。一、基于原生语法组装func DocSyncTaskCronJob() { ticker := time.NewTicker(time.Minute * 5) // 每分钟执行一次 for range ticker.C { ProcTask() }}func ProcTask() { log.Println("hello world")}二、基于 github 中封装的 cron 库实现package taskimport (_golang 定时任务

VC获取精确时间的方法_vc 通过线程和 sleep 获取精准时间-程序员宅基地

文章浏览阅读2.1k次。 来源:http://blog.csdn.net/clever101/archive/2008/10/18/3096049.aspx 声明:本文章是我整合网上的资料而成的,其中的大部分文字不是我所为的,我所起的作用只是归纳整理并添加我的一些看法。非常感谢引用到的文字的作者的辛勤劳动,所参考的文献在文章最后我已一一列出。 对关注性能的程序开发人员而言,一个好的计时部件既是益友,也_vc 通过线程和 sleep 获取精准时间