国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Java > 正文

SSH框架網(wǎng)上商城項(xiàng)目第9戰(zhàn)之添加和更新商品類別功能實(shí)現(xiàn)

2019-11-26 14:15:02
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

 上一節(jié)我們做完了查詢和刪除商品的功能,這一節(jié)我們做一下添加和更新商品的功能。
1. 添加商品類別
1.1 添加類別的UI設(shè)計(jì)
        我們先說(shuō)一下思路:首先當(dāng)用戶點(diǎn)擊“添加商品”時(shí),我們應(yīng)該彈出一個(gè)“添加商品”的UI窗口(注意這里不是跳轉(zhuǎn)到新的jsp,EasyUI只有一個(gè)頁(yè)面),彈出這個(gè)“添加商品”的窗口后,應(yīng)該鎖住它父類的所有窗口(即點(diǎn)擊其他地方無(wú)效,只能操作添加商品的窗口),等用戶填好了信息后,在新彈出來(lái)的窗口上點(diǎn)擊“添加”后,將請(qǐng)求發(fā)送給struts2,然后struts2拿到請(qǐng)求你參數(shù),從數(shù)據(jù)庫(kù)中執(zhí)行添加動(dòng)作,這樣后臺(tái)操作完成,同時(shí)前臺(tái)那邊要刷新一下當(dāng)前頁(yè)面,重新顯示所有商品。
        我們查看EasyUI的文檔,發(fā)現(xiàn)新建一個(gè)窗口有兩種方法,要么使用標(biāo)簽創(chuàng)建,要么使用js創(chuàng)建,我們這里使用js創(chuàng)建,但是需要一個(gè)<div>盒子,如下:


        另外,我們創(chuàng)建的新的窗口不需要最小化,最大化,但是要鎖屏。所以這些屬性都在div中設(shè)置好,這里要注意的就是鎖屏的功能,因?yàn)?lt;div>放的地方不同,鎖住的屏幕范圍也不同,我們要鎖住全屏,所以要把<div>放到aindex.jsp中,應(yīng)為aindex.jsp中產(chǎn)生了query.jsp的內(nèi)容(包括添加按鈕),query.jsp中產(chǎn)生了save.jsp的內(nèi)容(就是我們要顯示的添加窗口UI),所以彈出窗口后,我們要把a(bǔ)index.jsp的范圍都鎖住,所以<div>應(yīng)該放到aindex.jsp中,具體實(shí)現(xiàn)如下:
        在aindex.jsp的<body>中新添加一個(gè)<div>

復(fù)制代碼 代碼如下:
<div id="win" data-options="collapsible:false,minimizable:false,maximizable:false,modal:true"></div>
   
        然后我們完善query.jsp中添加類別的部分:

{  iconCls: 'icon-add',  text:'添加類別',  handler: function(){  parent.$("#win").window({ //因?yàn)?lt;div>放在了aindex.jsp中,所以這里創(chuàng)建窗口要先調(diào)用parent  title:"添加類別",  width:350,  height:150,  content:'<iframe src="send_category_save.action" frameborder="0" width="100%" height="100%"/>'  });  } } 

        從上面的添加類別代碼中可以看出,添加后的UI,我們引入WEB-INF/category目錄下的save.jsp文件中的內(nèi)容,接下來(lái)我們完成save.jsp:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>  <head>  <%@ include file="/public/head.jspf" %>  <style type="text/css">  form div {  margin:5px;  }  </style>  <script type="text/javascript">  $(function(){  $("input[name=type]").validatebox({ //這里是“類別名稱”的驗(yàn)證功能,如果用戶沒(méi)填好就提交的話,會(huì)有提示  required:true,  missingMessage:'請(qǐng)輸入類別名稱' //提示的內(nèi)容  });    //對(duì)管理員的下拉列表框進(jìn)行遠(yuǎn)程加載   $("#cc").combobox({   //將請(qǐng)求發(fā)送給accountAction中的query方法處理,這里需要將處理好的數(shù)據(jù)返回到這邊來(lái)顯示了 ,所以后臺(tái)需要將數(shù)據(jù)打包成json格式發(fā)過(guò)來(lái)   url:'account_query.action',   valueField:'id',   textField:'login', //我們下拉列表中顯示的是管理員的登錄名   panelHeight:'auto', //自適應(yīng)高度   panelWidth:120,//下拉列表是兩個(gè)組件組成的   width:120, //要同時(shí)設(shè)置兩個(gè)寬度才行   editable:false //下拉框不允許編輯   });   //窗體彈出默認(rèn)是禁用驗(yàn)證,因?yàn)閯倧棾龅拇翱冢脩暨€沒(méi)填就顯示的話,太丑  $("#ff").form("disableValidation");  //注冊(cè)button的事件。即當(dāng)用戶點(diǎn)擊“添加”的時(shí)候做的事  $("#btn").click(function(){  //開(kāi)啟驗(yàn)證  $("#ff").form("enableValidation");  //如果驗(yàn)證成功,則提交數(shù)據(jù)  if($("#ff").form("validate")) {   //調(diào)用submit方法提交數(shù)據(jù)   $("#ff").form('submit', {   url: 'category_save.action', //將請(qǐng)求提交給categoryAction中的save方法處理   success: function(){ //成功后   //如果成功了,關(guān)閉當(dāng)前窗口   parent.$("#win").window("close");   //刷新頁(yè)面,剛剛添加的就顯示出來(lái)了。     //獲取aindex-->iframe-->datagrid   parent.$("iframe[title='類別管理']").get(0).contentWindow.$("#dg").datagrid("reload");   }   });  }  });  });  </script>  </head>   <body>  <form id="ff" method="post">  <div>  <label for="name">商品名稱:</label> <input type="text" name="type" />  </div>  <div>  <label>所屬管理員:</label>  <input id="cc" name="account.id"/>  </div>  <div>  <label for="hot">熱點(diǎn):</label>  是<input type="radio" name="hot" value="true" />  否 <input type="radio" name="hot" value="true" />  </div>  <div>  <a id="btn" href="#" class="easyui-linkbutton" data-options="iconCls:'icon-add'">添加</a>  </div>  </form>  </body> </html> 

        前臺(tái)的顯示以及發(fā)送請(qǐng)求都做完了,接下來(lái)就是做后臺(tái)的程序了。
1.2 添加類別的邏輯實(shí)現(xiàn)
        前臺(tái)會(huì)把數(shù)據(jù)發(fā)送給categoryAction中的save方法去執(zhí)行,所以我們?nèi)慉ction就行了,因?yàn)楹笈_(tái)只需要將類別添加進(jìn)數(shù)據(jù)庫(kù),不需要向前臺(tái)返回?cái)?shù)據(jù),所以比較簡(jiǎn)單,直接寫好action就行了:

@Controller("categoryAction") @Scope("prototype") public class CategoryAction extends BaseAction<Category> {   //省略其他代碼……  public void save() {  System.out.println(model);  categoryService.save(model);  }  } 

這樣數(shù)據(jù)就存入數(shù)據(jù)庫(kù)了,完了后,前臺(tái)那邊刷新顯示,就能將新添加的商品類別顯示出來(lái)了,我們看一下

添加商品類別這一塊我們就做完了。下面做更新商品類別那塊。
2. 更新商品類別
2.1 更新類別的UI設(shè)計(jì)
        更新商品類別的思路和上面的添加的基本相同,首先也是彈出一個(gè)UI窗口,然后用戶填好數(shù)據(jù)發(fā)送給后臺(tái),后臺(tái)更新數(shù)據(jù)庫(kù),前臺(tái)再刷新顯示。我們?nèi)匀徊捎蒙厦娴姆椒▌?chuàng)建一個(gè)UI窗口。<div>盒子不用改動(dòng)什么,我們需要做的就是在query.jsp中完善更“更新類別”部分的代碼:

{  iconCls: 'icon-edit',  text:'更新類別',  handler: function(){  //判斷是否有選中行記錄,使用getSelections獲取選中的所有行  var rows = $("#dg").datagrid("getSelections");  if(rows.length == 0) {  //彈出提示信息  $.messager.show({ //語(yǔ)法類似于java中的靜態(tài)方法,直接對(duì)象調(diào)用  title:'錯(cuò)誤提示',  msg:'至少要選擇一條記錄',  timeout:2000,  showType:'slide',  });  }else if(rows.length != 1) {  //彈出提示信息  $.messager.show({ //語(yǔ)法類似于java中的靜態(tài)方法,直接對(duì)象調(diào)用  title:'錯(cuò)誤提示',  msg:'每次只能更新一條記錄',  timeout:2000,  showType:'slide',  });  } else{  //1. 彈出更新的頁(yè)面  parent.$("#win").window({  title:"添加類別",  width:350,  height:250,  content:'<iframe src="send_category_update.action" frameborder="0" width="100%" height="100%"/>'  });  //2.  }  } } 

       我們分析一下上面的js代碼:首先獲取用戶勾選要更新的行,如果沒(méi)有選中則提示用戶至少需要選中一項(xiàng)紀(jì)錄去更新,如果選中的不止一條紀(jì)錄,也得提示用戶每次只能更新一條紀(jì)錄。當(dāng)這些判斷都結(jié)束后,保證了用戶勾選了一條紀(jì)錄,那么我們開(kāi)始創(chuàng)建新的UI窗口了,這里還是跟上面一樣,引入WEB-INF/category目錄下的update.jsp頁(yè)面的內(nèi)容,我們來(lái)看下update.jsp頁(yè)面內(nèi)容:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>  <head>  <%@ include file="/public/head.jspf" %>  <style type="text/css">  form div {  margin:5px;  }  </style>  <script type="text/javascript">  $(function(){  //iframe中的datagrid對(duì)象  var dg = parent.$("iframe[title='類別管理']").get(0).contentWindow.$("#dg");   //對(duì)管理員的下拉列表框進(jìn)行遠(yuǎn)程加載  $("#cc").combobox({  //將請(qǐng)求發(fā)送給accountAction中的query方法處理,這里需要將處理好的數(shù)據(jù)返回到這邊來(lái)顯示了 ,所以后臺(tái)需要將數(shù)據(jù)打包成json格式發(fā)過(guò)來(lái)  url:'account_query.action',  valueField:'id',  textField:'login', //我們下拉列表中顯示的是管理員的登錄名  panelHeight:'auto', //自適應(yīng)高度  panelWidth:120,//下拉列表是兩個(gè)組件組成的  width:120, //要同時(shí)設(shè)置兩個(gè)寬度才行  editable:false //下拉框不允許編輯  });   // 完成數(shù)據(jù)的回顯,更新時(shí),用戶肯定先選擇了要更新的那一行,首先我們得拿到那一行  var rows = dg.datagrid("getSelections");  //將拿到的那一行對(duì)應(yīng)的數(shù)據(jù)字段加載到表單里,實(shí)現(xiàn)回顯  $("#ff").form('load',{  id:rows[0].id,  type:rows[0].type,   hot:rows[0].hot,  'account.id':rows[0].account.id //EasyUI不支持account.id這種點(diǎn)操作,所以要加個(gè)引號(hào)  });   //回顯完了數(shù)據(jù)后,設(shè)置一下驗(yàn)證功能  $("input[name=type]").validatebox({  required:true,  missingMessage:'請(qǐng)輸入類別名稱'  });  //窗體彈出默認(rèn)時(shí)禁用驗(yàn)證  $("#ff").form("disableValidation");  //注冊(cè)button的事件  $("#btn").click(function(){  //開(kāi)啟驗(yàn)證  $("#ff").form("enableValidation");  //如果驗(yàn)證成功,則提交數(shù)據(jù)  if($("#ff").form("validate")) {   //調(diào)用submit方法提交數(shù)據(jù)   $("#ff").form('submit', {   url: 'category_update.action', //提交時(shí)將請(qǐng)求傳給categoryAction的update方法執(zhí)行   success: function(){   //如果成功了,關(guān)閉當(dāng)前窗口,并刷新頁(yè)面   parent.$("#win").window("close");   dg.datagrid("reload");   }   });  }  });  });  </script>  </head>   <body>  <form id="ff" method="post">  <div>  <label for="name">類別名稱:</label> <input type="text" name="type" />  </div>  <div>  <label for="hot">熱點(diǎn):</label>  是<input type="radio" name="hot" value="true" />  否<input type="radio" name="hot" value="false" />  </div>  <div>  <label for="account">所屬管理員:</label>  <!-- 下拉列表我們采用遠(yuǎn)程加載的方法加載管理員數(shù)據(jù) -->  <input id="cc" name="account.id" />  </div>  <div>  <a id="btn" href="#" class="easyui-linkbutton" data-options="iconCls:'icon-edit'">更新</a>  <input type="hidden" name="id" />  </div> `  </form>  </body> </html> 

        更新與添加不同的地方在于,首先得數(shù)據(jù)回顯,然后還有個(gè)下拉列表顯示管理員數(shù)據(jù),因?yàn)樗鶎俟芾韱T也要更新。我們看看上面的代碼,首先使用遠(yuǎn)程加載的方法加載管理員數(shù)據(jù),先向后臺(tái)發(fā)送一個(gè)請(qǐng)求,后臺(tái)accountAction的query方法處理完后,管理員數(shù)據(jù)打包成json格式返回回來(lái),這樣就能拿到管理員數(shù)據(jù)了,拿到后,就可以進(jìn)行數(shù)據(jù)的回顯了。我們看一下后臺(tái)的程序:
2.2 更新類別的邏輯實(shí)現(xiàn)

@Controller("baseAction") @Scope("prototype") public class BaseAction<T> extends ActionSupport implements RequestAware,SessionAware,ApplicationAware,ModelDriven<T> {   //用來(lái)裝有將要被打包成json格式返回給前臺(tái)的數(shù)據(jù),下面要實(shí)現(xiàn)get方法  protected List<T> jsonList = null;  //省略其他方法……  }  //AccountAction @Controller("accountAction") @Scope("prototype") public class AccountAction extends BaseAction<Account> {   public String query() {  jsonList = accountService.query();  return "jsonList";  }  } 

        接下來(lái)我們配置一下struts.xml文件:

<action name="account_*" class="accountAction" method="{1}">  <result name="jsonList" type="json">  <param name="root">jsonList</param>  <param name="excludeProperties">  <!-- [0].pass, [1].pass -->  <!-- 正則表達(dá)式顯示有bug,我下面截個(gè)圖 -->  </param>  </result> </action> 

完成回顯后,就是更新操作了,當(dāng)然也有驗(yàn)證的功能,和添加一樣的,更新操作將請(qǐng)求傳給categoryAction的update方法執(zhí)行,比較簡(jiǎn)單:

@Controller("categoryAction") @Scope("prototype") public class CategoryAction extends BaseAction<Category> {  //省略其他方法……  public void update() {  System.out.println(model);  categoryService.update(model);  } } 

到此,我們完成了商品類別的添加和更新操作。

原文地址:http://blog.csdn.net/eson_15/article/details/51347734

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 信阳市| 尚志市| 绵竹市| 巴南区| 夹江县| 康乐县| 罗定市| 公安县| 高唐县| 察隅县| 焦作市| 长阳| 洛川县| 宁阳县| 张家港市| 承德县| 集贤县| 改则县| 新营市| 河东区| 乌兰浩特市| 镇坪县| 宣化县| 西和县| 永胜县| 富顺县| 确山县| 容城县| 临高县| 通山县| 铁岭县| 东光县| 安阳县| 邯郸市| 民权县| 遂川县| 扶绥县| 岳西县| 杨浦区| 凤城市| 阿克苏市|