前后台交互经常使用的技术汇总(后台:Java技术,前台:Js或者Jquery)
1:由于針對(duì)特定的前后臺(tái)交互用到的知識(shí)總結(jié),所以不大量貼代碼,主要給出思路,方便自己以后腦補(bǔ)和技術(shù)總結(jié),當(dāng)然也希望可以幫助到別人。
后臺(tái)Json和其他格式轉(zhuǎn)化,之前總結(jié)過(guò)Json和對(duì)象,集合,字符串的轉(zhuǎn)化或者互相轉(zhuǎn)化,這里我想網(wǎng)上有很多demo。
servlet,或者strtus2或者SpringMvc,在控制層將傳遞到前臺(tái)的數(shù)據(jù)進(jìn)行封裝或者轉(zhuǎn)化為Json,對(duì)你的開(kāi)發(fā)十分有幫助。
案例一:當(dāng)前臺(tái)申請(qǐng)或者取消按鈕的時(shí)候,前臺(tái)根據(jù)操作顯示對(duì)應(yīng)的提示,非彈出框。
(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 //這里將前臺(tái)的兩種操作返回的數(shù)據(jù)分別,保存到map里面。 10 map.put("返回的數(shù)據(jù)1", 返回的數(shù)據(jù)1); 11 map.put("返回的數(shù)據(jù)2", 返回的數(shù)據(jù)2); 12 //然后使用JsonUtil,這個(gè)封裝好的Json轉(zhuǎn)化工具類,將map類型轉(zhuǎn)化為Json類型的。Java的map集合類型轉(zhuǎn)化為Json類型。 13 String json = JOSNUtil.object2String(map); 14 //將轉(zhuǎn)化后的數(shù)據(jù)傳遞給前臺(tái)的Ajax的function(data){}的data. 15 response.getWriter().write(json); 16 //刷新操作 17 response.getWriter().flush();(2):前臺(tái)使用Jquery進(jìn)行后臺(tái)數(shù)據(jù)處理:Jquery速查網(wǎng)址
1 function 方法名稱(參數(shù)){ 2 ...操作 3 ...操作 4 ...操作 5 //$.post的用法自行查閱 6 $.post( 7 url:發(fā)送請(qǐng)求地址, 8 data:待發(fā)送 Key/value 參數(shù), 9 function(data){ 10 //alert(data);//可以打印傳過(guò)來(lái)的參數(shù) 11 //解析后臺(tái)傳過(guò)來(lái)的map轉(zhuǎn)成的json格式的字符,Java的map集合類型轉(zhuǎn)化為Json類型。 12 //eval() 函數(shù)可計(jì)算某個(gè)字符串,并執(zhí)行其中的的 JavaScript 代碼。 13 var json = eval("(" + data + ")"); 14 //直接使用json.key的形式進(jìn)行獲取 15 if(json.返回的數(shù)據(jù)1!=null){ 16 //js循環(huán)遍歷返回的值,注我的map的value是數(shù)組類型的(Object)。 17 for(var i=0;i< json.返回的數(shù)據(jù)1.length;i++){ 18 //獲取到這個(gè)id是為了動(dòng)態(tài)根據(jù)某一個(gè)角色id來(lái)追加內(nèi)容。 19 var roleId = json.返回的數(shù)據(jù)1[i]; 20 //動(dòng)態(tài)根據(jù)某一個(gè)角色id來(lái)追加內(nèi)容。"#"+roleId代表選擇器動(dòng)態(tài)變化。 21 $("#"+roleId).append('<span style="color:red;">(申請(qǐng)權(quán)限待審批)</span>'); 22 //此句話的,查找每個(gè)動(dòng)態(tài)id元素的所有類名為 "selected" 的所有同胞元素: 23 //然后attr() 方法設(shè)置或返回被選元素的屬性值。 24 //然后設(shè)置一下checkbox為不選中,且disabled不可選。 25 $("#"+roleId).siblings().attr("checked",false).attr("disabled",true); 26 } 27 } 28 //同上 29 if(json.返回的數(shù)據(jù)2!=null){ 30 for(var i=0;i< json.返回的數(shù)據(jù)2.length;i++){ 31 var roleId= json.返回的數(shù)據(jù)2[i] 32 $("#"+roleId).append('<span style="color:red;">(申請(qǐng)注銷待審批)</span>'); 33 $("#"+roleId).siblings().attr("checked",false).attr("disabled",true); 34 } 35 } 36 }); 37 38 }案例二:根據(jù)id動(dòng)態(tài)變化傳遞到后臺(tái),ajax異步請(qǐng)求,刷新前臺(tái)顯示內(nèi)容。
(1):此處使用SpringMvc作為Controller層。
1 //根據(jù)角色id獲取資源信息/index/getResource 2 //@ResponseBody將返回值轉(zhuǎn)化為json格式響應(yīng)到客戶端 3 @RequestMapping(value="/getResource",method=RequestMethod.POST) 4 public @ResponseBody List<Object> roleGetResource(HttpServletRequest request, HttpServletResponse response) 5 throws Exception{ 6 //設(shè)置編碼格式 7 response.setCharacterEncoding("utf-8"); 8 9 //獲取到角色的編號(hào) 10 String roleId = request.getParameter("roleId"); 11 12 //開(kāi)始根據(jù)角色的編號(hào)查詢其下的權(quán)限資源 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 //只獲取到資源的名稱,返回到前臺(tái)即可 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 //將資源的名稱傳遞到前臺(tái)的function(data){}的data. 25 return list; 26 }?(2):前臺(tái)使用Jquery進(jìn)行后臺(tái)數(shù)據(jù)處理:Jquery速查網(wǎng)址
1 $(document).ready(function(){ 2 var roleId = null; 3 //獲取到所有的角色RoleId 4 $(".roleId").each(function(){ 5 //當(dāng)鼠標(biāo)移動(dòng)到角色名稱,觸發(fā)事件,鼠標(biāo)移入效果 6 $(this).mouseover(function(){ 7 //鼠標(biāo)點(diǎn)擊效果,觸發(fā)事件,鼠標(biāo)移入效果 8 //$(this).click(function(){ 9 //此句話獲取到該span的id屬性的值。 10 roleId = $(this).attr("id"); 11 //alert(roleId); 12 //調(diào)用ajax異步請(qǐng)求,獲取角色下面的資源 13 $.ajax({ 14 type : "POST",//post類型請(qǐng)求。 15 data : {"roleId":roleId},//將每一次獲取到角色id傳遞到后臺(tái)。 16 url : "../right/getResource",//請(qǐng)求后臺(tái)的路徑 17 success : function(resourceByRole) {//參數(shù)即后臺(tái)返回的數(shù)據(jù)。 18 //alert(resourceByRole);//先測(cè)試一下返回的數(shù)據(jù)是否正確 19 //判斷是否為空或者為null 20 if(resourceByRole == null || resourceByRole == ""){ 21 //然后根據(jù)div的class屬性進(jìn)行追加或者顯示內(nèi)容即可。 22 $(".resourceShow").html('<span style="color:red;">此角色下面沒(méi)有權(quán)限</span>'); 23 }else{ 24 // 25 $(".resourceShow").text(resourceByRole); 26 } 27 }, 28 }); 29 }) 30 }); 31 });案例三:根據(jù)jqPaginator分頁(yè)插件,實(shí)現(xiàn)異步動(dòng)態(tài)加載自己的數(shù)據(jù),刷新前臺(tái)顯示分頁(yè)內(nèi)容。
3:官網(wǎng)就是這個(gè)樣子,不過(guò)github的頁(yè)面貌似沒(méi)法顯示:http://jqpaginator.keenwon.com/
(1)前臺(tái)展示,由于項(xiàng)目的原因,前臺(tái)進(jìn)行閹割了,必要內(nèi)容都貼出來(lái)了:
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>jqpaginator分頁(yè)</title> 6 <link rel="stylesheet" href="../css/bootstrap.min.css"> 7 <!--引入必須的插件,畢竟使用別人的插件--> 8 <script src="../js/jquery-2.1.1.min.js" type="text/javascript"></script> 9 <script src="../js/bootstrap.min.js" type="text/javascript"></script> 10 <script src="../js/jqPaginator.min.js" type="text/javascript"></script> 11 </head> 12 <body> 13 14 15 <table> 16 <thead> 17 <tr role="row"> 18 <th >編號(hào)</th> 19 <th>時(shí)間</th> 20 <th>IP地址</th> 21 <th>操作對(duì)象</th> 22 <th>操作事件</th> 23 <th>結(jié)果</th> 24 </tr> 25 </thead> 26 <tbody id="tbody"> 27 <%-- 28 <c:forEach items="${logList }" var="logList" varStatus="status" begin="0" step="1"> 29 <tr class="gradeX"> 30 <td class="">${status.count}</td> 31 <td class="sorting_1">${logList.LOG_TIME}</td> 32 <td class="">${logList.LOG_SRC_IP}</td> 33 <td class="">${logList.APP_NAME}</td> 34 <td class="center">${logList.LOG_NAME}</td> 35 <td class="center">${logList.LOG_RESULT_DESC}</td> 36 </tr> 37 </c:forEach> 38 --%> 39 </tbody> 40 </table> 41 42 <!---必須加id="pagination"--> 43 <ul id="pagination" id="pagination2"></ul> 44 45 <!-- 分頁(yè)操作 --> 46 <script type="text/javascript"> 47 function getJsonLength(json){ 48 var jsonLength=0; 49 for (var i in json) { 50 jsonLength++; 51 } 52 return jsonLength; 53 } 54 55 $.jqPaginator('#pagination', { 56 totalPages: 5,//分頁(yè)的總頁(yè)數(shù);默認(rèn)0 57 visiblePages: 10,//最多顯示的頁(yè)碼數(shù) 58 //totalCounts: 10,//分頁(yè)的總條目數(shù);默認(rèn)0 59 //pageSize: 10,//每一頁(yè)的條目數(shù);默認(rèn)0 60 currentPage: 1,//默認(rèn)顯示第幾頁(yè) 61 wrapper:'<ul class="pagination"></ul>', 62 first: '<li class="first"><a href="javascript:void(0);">首頁(yè)</a></li>', 63 prev: '<li class="prev"><a href="javascript:void(0);">上一頁(yè)</a></li>', 64 page: '<li class="page"><a href="javascript:void(0);">{{page}}</a></li>', 65 next: '<li class="next"><a href="javascript:void(0);">下一頁(yè)</a></li>', 66 last: '<li class="last"><a href="javascript:void(0);">末頁(yè)</a></li>', 67 onPageChange: function (num) { 68 $.ajax({ 69 url: "../log/logList", 70 type: "POST", 71 dataType: 'json', 72 data: {"num": num}, 73 success : function(data) { 74 //得到j(luò)son值 75 var jsonLength = getJsonLength(data) - 1; 76 var html = ''; 77 //初始化后,動(dòng)態(tài)修改配置,首先獲取多少行,算出需要分幾頁(yè) 78 var totalCount = data[jsonLength].totalCount; 79 var pageTotal = Math.floor(totalCount / 10 + 1); 80 $('#pagination').jqPaginator('option', { 81 //根據(jù)返回的總條目數(shù)動(dòng)態(tài)顯示頁(yè)碼總數(shù) 82 totalPages: pageTotal 83 }); 84 //清空table里面的數(shù)據(jù) 85 $('#tbody').empty(); 86 //循環(huán)遍歷json字符串,然后動(dòng)態(tài)賦值 87 for(var i=0;i<jsonLength;i++){ 88 var LOG_TIME = data[i].LOG_TIME; 89 var LOG_SRC_IP = data[i].LOG_SRC_IP; 90 var APP_NAME = data[i].APP_NAME; 91 var LOG_NAME = data[i].LOG_NAME; 92 var LOG_RESULT_DESC = data[i].LOG_RESULT_DESC; 93 html += '<tr>' + 94 '<td>' + LOG_TIME + '</td>' + 95 '<td>' + LOG_SRC_IP + '</td>' + 96 '<td>' + APP_NAME + '</td>' + 97 '<td>' + LOG_NAME + '</td>' + 98 '<td>' + LOG_RESULT_DESC + '</td>' + 99 '</tr>'; 100 } 101 $('#tbody').append(html); 102 } 103 }); 104 } 105 }); 106 </script> 107 108 109 </body> 110 </html>(2)SpringMvc對(duì)數(shù)據(jù)進(jìn)行處理和控制,由于直接調(diào)用別人寫(xiě)好的接口,控制層代碼也許不適合你(奇葩的是,項(xiàng)目點(diǎn)擊左邊的欄目,跳轉(zhuǎn)到一個(gè)頁(yè)面,然后使用ajax異步加載出分頁(yè)數(shù)據(jù)。):
JsonUtils工具類,也行不是很適合你,將java的List<Map<key,value>>轉(zhuǎn)化為Json格式的;:
1 public class JOSNUtil { 2 3 4 public static String object2String(Object data) throws IOException { 5 ObjectMapper om = new ObjectMapper(); 6 SimpleFilterProvider filterProvider = new SimpleFilterProvider().setFailOnUnknownId(false); 7 om.setFilters(filterProvider); 8 return om.writeValueAsString(data); 9 } 10 /** 11 * 12 * json轉(zhuǎn)換list. 13 * <br>詳細(xì)說(shuō)明 14 * @param jsonStr json字符串 15 * @return 16 * @return List<Map<String,Object>> list 17 * @throws 18 * @author slj 19 * @date 2013年12月24日 下午1:08:03 20 */ 21 public static List<Map<String, Object>> parseJSON2List(String jsonStr){ 22 JSONArray jsonArr = JSONArray.fromObject(jsonStr); 23 List<Map<String, Object>> list = new ArrayList<Map<String,Object>>(); 24 Iterator<JSONObject> it = jsonArr.iterator(); 25 while(it.hasNext()){ 26 JSONObject json2 = it.next(); 27 list.add(parseJSON2Map(json2.toString())); 28 } 29 return list; 30 } 31 32 /** 33 * 34 * json轉(zhuǎn)換map. 35 * <br>詳細(xì)說(shuō)明 36 * @param jsonStr json字符串 37 * @return 38 * @return Map<String,Object> 集合 39 * @throws 40 * @author slj 41 */ 42 public static Map<String, Object> parseJSON2Map(String jsonStr){ 43 ListOrderedMap map = new ListOrderedMap(); 44 //最外層解析 45 JSONObject json = JSONObject.fromObject(jsonStr); 46 for(Object k : json.keySet()){ 47 Object v = json.get(k); 48 //如果內(nèi)層還是數(shù)組的話,繼續(xù)解析 49 if(v instanceof JSONArray){ 50 List<Map<String, Object>> list = new ArrayList<Map<String,Object>>(); 51 Iterator<JSONObject> it = ((JSONArray)v).iterator(); 52 while(it.hasNext()){ 53 JSONObject json2 = it.next(); 54 list.add(parseJSON2Map(json2.toString())); 55 } 56 map.put(k.toString(), list); 57 } else { 58 map.put(k.toString(), v); 59 } 60 } 61 return map; 62 } 63 }然后寫(xiě)控制層代碼,如下所示:
1 @RequestMapping(value="/logList",method=RequestMethod.POST) 2 protected @ResponseBody void getLogTable(final HttpServletRequest request, final HttpServletResponse response) 3 throws Exception { 4 response.setCharacterEncoding("utf-8"); 5 //獲取到用戶的id 6 Map<String,Object> userMap=getLoginUser(request); 7 String userId=String.valueOf(userMap.get(TbUser.USER_ID.name)); 8 //封裝查詢條件 9 Map<String, Object> searchCond = new HashMap<String, Object>(); 10 searchCond.put(TbLog.USER_ID.name, userId); 11 List<Map<String, Object>> logList = null; 12 13 14 //日志總數(shù) 15 int totalCount = bizLog.getLogCount(searchCond); 16 //獲取到第幾頁(yè), 17 String Pagenum = request.getParameter("num"); 18 System.out.println("Pagenum:" + Pagenum); 19 if(Pagenum == null){ 20 Pagenum = "0"; 21 } 22 //日志總數(shù) 23 //int totalCount = bizLog.getLogCount(searchCond); 24 //獲取到當(dāng)前頁(yè)數(shù) 25 int currentPageNum = Integer.parseInt(Pagenum); 26 //顯示的條數(shù) 27 int pageLength = 10; 28 //起始值 29 int startRow = (currentPageNum-1) * pageLength + 1; 30 //第幾頁(yè) 31 //int totalPage = totalCount / pageLength + 1; 32 33 Map<String, Object> totalCountCond = new HashMap<String, Object>(); 34 //判斷Session中該值是否為空 35 if (userId != null) { 36 //根據(jù)參數(shù)查詢?nèi)罩拘畔?#xff0c;參數(shù)2是從第幾個(gè)開(kāi)始,即起始值。參數(shù)3是每頁(yè)多少條數(shù)據(jù)。 37 logList = bizLog.getLogList(searchCond, startRow, pageLength); 38 totalCountCond.put("totalCount", totalCount);//這里封裝一下查詢的總數(shù),然后傳給前臺(tái)解析出來(lái),設(shè)置顯示多少頁(yè)碼總數(shù) 39 logList.add(totalCountCond); 40 } 41 System.out.println(JOSNUtil.object2String(logList)); 42 //轉(zhuǎn)換為JSON格式 43 response.getWriter().write(JOSNUtil.object2String(logList)); 44 response.getWriter().flush(); 45 response.getWriter().close(); 46 }?顯示如下,反正吧,都是公司的項(xiàng)目,代碼啊,截圖啊,都是閹割的,湊活著看吧:
?
?待續(xù)......
新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎(jiǎng)!定制產(chǎn)品紅包拿不停!總結(jié)
以上是生活随笔為你收集整理的前后台交互经常使用的技术汇总(后台:Java技术,前台:Js或者Jquery)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: OGG学习笔记02
- 下一篇: Java语言中的----数组