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 });
待续......