說(shuō)明:前端使用layui,后端spring mvc.
頁(yè)面是這樣的:
代碼:
<script id="secRoleFunctionTpl" type="text/html">
<div style="padding-top: 30px;padding-left:20px; margin-right: 50px">
<form class="layui-form layui-form-pane" id="secRoleFunctionForm">
<div class="layui-form-item">
{{# layui.each(d.list, function(index, item){ }}
<div class="layui-form-item">
<label class="layui-form-label formLabel-100">一級(jí)菜單</label>
<div class="layui-input-block">
{{# if(item.isChecked){ }}
<input type="checkbox" name="fristFunc" title="{{item.fristFunc.funcName}}"
data-value="{{item.fristFunc.fid}}" lay-filter="fristFuncCheckbox"
checked>
{{# } }}
{{# if(!item.isChecked){ }}
<input type="checkbox" name="fristFunc" title="{{item.fristFunc.funcName}}"
data-value="{{item.fristFunc.fid}}" lay-filter="fristFuncCheckbox"
>
{{# } }}
</div>
</div>
<div class="layui-form-item">
<label class="layui-form-label formLabel-100">二級(jí)菜單</label>
<div class="layui-input-block">
{{# layui.each(item.secondFuncList, function(indexChild, itemChild){ }}
{{# if(item.fristFunc.fid==itemChild.parentFid){ }}
{{# if(itemChild.isChecked){ }}
<input type="checkbox" name="secondFuncList" title="{{itemChild.funcName}}"
data-value="{{itemChild.fid}}" lay-filter="secondFuncCheckbox"
checked>
{{# } }}
{{# if(!itemChild.isChecked){ }}
<input type="checkbox" name="secondFuncList" title="{{itemChild.funcName}}"
data-value="{{itemChild.fid}}" lay-filter="secondFuncCheckbox"
>
{{# } }}
{{# } }}
{{# }); }}
</div>
</div>
{{# }); }}
<div class="layui-input-block">
<button class="layui-btn" lay-submit lay-filter="secRoleFunctionButton">立即提交</button>
<button type="reset" class="layui-btn layui-btn-primary">重置</button>
</div>
</div>
</form>
</div>
</script>
如上所示,每個(gè)checkbox都有一個(gè)fid。因?yàn)椴藛螖?shù)量是動(dòng)態(tài)的,所以使用List<SecRoleFuncVO>的方式來(lái)做數(shù)據(jù)保存。結(jié)構(gòu)如下:
public class SecRoleFuncVO implements Serializable {
private SecFunction fristFunc;
private List<SecFunction> secondFuncList;
private Integer roid;
public Integer getRoid() {
return roid;
}
public void setRoid(Integer roid) {
this.roid = roid;
}
public SecFunction getFristFunc() {
return fristFunc;
}
public void setFristFunc(SecFunction fristFunc) {
this.fristFunc = fristFunc;
}
public List<SecFunction> getSecondFuncList() {
return secondFuncList;
}
public void setSecondFuncList(List<SecFunction> secondFuncList) {
this.secondFuncList = secondFuncList;
}
}
roid是固定的,并不用管。至于SecFunction類的結(jié)構(gòu),它里面差不多只有一個(gè)int型的fid字段。換句話說(shuō),其實(shí)整個(gè)頁(yè)面就是要取這些checkbox的fid值就好了。
但是有個(gè)問(wèn)題,控制器的參數(shù)不接受類集合,所以我又建了一個(gè)類來(lái)保存上面的List<SecRoleFuncVO>:
public class ParameterList implements Serializable {
private List<SecRoleFuncVO> secRoleFuncVOList;
public List<SecRoleFuncVO> getSecRoleFuncVOList() {
return secRoleFuncVOList;
}
public void setSecRoleFuncVOList(List<SecRoleFuncVO> secRoleFuncVOList) {
this.secRoleFuncVOList = secRoleFuncVOList;
}
}
然后控制器的代碼:
/**
* 保存或修改已分配的菜單
*
* @param paramList
* @return
*/
@RequestMapping("/saveOrUpSecRoleFunction")
@ResponseBody
public Json saveOrUpSecRoleFunction(ParameterList paramList) {
Json json = new Json();
try {
secService.saveOrUpSecRoleFunction(paramList.getSecRoleFuncVOList());
json.setSuccess(true);
} catch (Exception e) {
e.printStackTrace();
json.setMsg(e.getMessage());
}
return json;
}
接著是把頁(yè)面的值取過(guò)來(lái)。本來(lái)如果只有一條數(shù)據(jù),那么按說(shuō)控制器參數(shù)的類會(huì)自動(dòng)識(shí)別頁(yè)面上的控件名,但是這個(gè)頁(yè)面是動(dòng)態(tài)的,并且有一級(jí),二級(jí)兩層,數(shù)據(jù)會(huì)有N條。所以我只能選擇在js里寫:
//分配菜單事件
function secRoleFunction(roid) {
var result = $.loadData('/sec/querySecRoleFunctionByRoid?roid=' + roid);
if (!result.success) {
layer.msg(result.msg);
} else {
openSecRoleFunction('分配菜單', result.obj, roid);
}
}
// 提交菜單
function openSecRoleFunction(title, Data, roid) {
var tplHtml;
var data = {'list': Data};
layui.laytpl(secRoleFunctionTpl.innerHTML).render(data, function (html) {
tplHtml = html;
});
layerIndex = layer.open({
type: 1,
title: title,
area: ['400', '400'],
success: function () {
form = layui.form;
form.render();
$('#secRoleFunctionForm')[0].reset();
form.on('submit(secRoleFunctionButton)', function (data) {
var object = data.field;
var SecRoleFuncVOList = new Array();//實(shí)體集合
$('input:checkbox[name="fristFunc"]:checked').each(function (indexFirst, itemFirst) {//循環(huán)一級(jí)菜單
var SecRoleFuncVO = {};//實(shí)體
//角色編號(hào)
SecRoleFuncVO['roid'] = roid;
//一級(jí)菜單
var fristFunc = {fid: $(itemFirst).data('value')};
SecRoleFuncVO['fristFunc'] = fristFunc;
//二級(jí)菜單
var secondItem = $(itemFirst).parent().parent().next().children('div').children('input:checkbox[name="secondFuncList"]:checked');
var secondFuncList = new Array();//二級(jí)菜單集合
secondItem.each(function (indexSecond, itemSecond) {
var secondFunc = {fid: $(itemSecond).data('value')};
secondFuncList.push(secondFunc);
});
SecRoleFuncVO['secondFuncList'] = secondFuncList;
SecRoleFuncVOList.push(SecRoleFuncVO);
});
var paramList = {};//實(shí)體
paramList['secRoleFuncVOList'] = SecRoleFuncVOList;
object = paramList;
console.table(object);
layer.msg('提交中,請(qǐng)稍候', {icon: 16, time: false, shade: 0.8});
$.post('/sec/saveOrUpSecRoleFunction', object ,
function (data) {
if (data.success) {
layer.close(layerIndex);
layer.msg("操作成功!");
} else {
layer.msg(data.msg);
}
}
);
return false;
}
);
}
,
shadeClose: true,
area:
['1000px', '600px'],
content:
tplHtml
})
;
}
調(diào)試時(shí)結(jié)果很正常(請(qǐng)參照SecRoleFuncVO類):
但是,根本不進(jìn)控制器,并且報(bào)了這個(gè)錯(cuò)誤:
如果我將js中的
var paramList = {};//實(shí)體
paramList['secRoleFuncVOList'] = SecRoleFuncVOList;
object = paramList;
改成
object =SecRoleFuncVOList;
那么能進(jìn)控制器,但結(jié)果是這樣:
也就是說(shuō),不管我怎么寫,值就是進(jìn)不了控制器,請(qǐng)問(wèn)這個(gè)要怎么解決呢?
或者說(shuō),各位大神有更好的方法讓頁(yè)面的值傳進(jìn)后臺(tái)嗎?(比如不通過(guò)js)
已解決
首先js不使用$.post,而是使用:
$.ajax({
type: "post",
url: '/sec/saveOrUpSecRoleFunction',
dataType: "json",
contentType: 'application/json;charset=utf-8',
data: JSON.stringify(SecRoleFuncVOList),//此塊注意
success: function (data) {
if (data.success) {
layer.close(layerIndex);
layer.msg("操作成功!");
} else {
layer.msg(data.msg);
}
}
});
控制器也不用再把類集合放到一個(gè)類中,直接傳參就可以:
@RequestMapping("/saveOrUpSecRoleFunction")
@ResponseBody
public Json saveOrUpSecRoleFunction(@RequestBody List<SecRoleFuncVO> secRoleFuncVOS) {
Json json = new Json();
try {
// secService.saveOrUpSecRoleFunction(paramList.getSecRoleFuncVOList());
json.setSuccess(true);
} catch (Exception e) {
e.printStackTrace();
json.setMsg(e.getMessage());
}
return json;
}北大青鳥(niǎo)APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
北大課工場(chǎng)是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國(guó)家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國(guó)制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級(jí)產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國(guó)職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開(kāi)發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_(kāi)發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開(kāi)發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁(yè)制作和網(wǎng)頁(yè)游戲開(kāi)發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開(kāi)發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問(wèn),美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。