SSH框架網(wǎng)上商城項(xiàng)目第9戰(zhàn)之添加和更新商品類別功能實(shí)現(xiàn)
上一節(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>
然后我們完善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(){
//開啟驗(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ì)錄,那么我們開始創(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(){
//開啟驗(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í)有所幫助,也希望大家多多支持腳本之家。
- php網(wǎng)上商城購(gòu)物車設(shè)計(jì)代碼分享
- php 網(wǎng)上商城促銷設(shè)計(jì)實(shí)例代碼
- SSH框架的常見(jiàn)問(wèn)題和解決方法
- SSH+Jquery+Ajax框架整合
- SSH網(wǎng)上商城之使用ajax完成用戶名是否存在異步校驗(yàn)
- Java的web開發(fā)中SSH框架的協(xié)作處理應(yīng)用筆記
- java網(wǎng)上商城開發(fā)之郵件發(fā)送功能(全)
- SSH框架網(wǎng)上商城項(xiàng)目第8戰(zhàn)之查詢和刪除商品類別功能實(shí)現(xiàn)
- SSH框架網(wǎng)上商城項(xiàng)目第23戰(zhàn)之在線支付功能實(shí)現(xiàn)
- SSH框架網(wǎng)上商城項(xiàng)目第30戰(zhàn)之項(xiàng)目總結(jié)(附源碼下載地址)
相關(guān)文章
spring boot設(shè)置過(guò)濾器、監(jiān)聽(tīng)器及攔截器的方法
這篇文章主要給大家介紹了關(guān)于spring boot設(shè)置過(guò)濾器、監(jiān)聽(tīng)器及攔截器的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
java方法重載和參數(shù)類型自動(dòng)提升方式
這篇文章主要介紹了java方法重載和參數(shù)類型自動(dòng)提升方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
Spring在@ConditionalOnProperty注解使用詳解
這篇文章主要介紹了Spring在@ConditionalOnProperty注解使用詳解,@ConditionalOnProperty注解是Spring Boot的條件注解,主要用法是根據(jù)配置文件中的屬性來(lái)控制某個(gè)配置類是否生效,或者控制某個(gè)Bean是否被創(chuàng)建,需要的朋友可以參考下2023-11-11
spring mvc 讀取xml文件數(shù)據(jù)庫(kù)配置參數(shù)的方法
下面小編就為大家?guī)?lái)一篇spring mvc 讀取xml文件數(shù)據(jù)庫(kù)配置參數(shù)的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
SpringBoot全局配置long轉(zhuǎn)String丟失精度問(wèn)題解決方案
這篇文章主要介紹了SpringBoot全局配置long轉(zhuǎn)String丟失精度問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08

