JQuery:
首先在页面要先获取到你选择的数据,我这里获取到的是layui表格中的某条数据,所以用的是拼接口ID的方式,获取到选中数据的ID,再在控制器通过ID查询出来所需要的数据!拼接完ID之后,用一个post请求把拼接好的字符串ID传到控制器中去。
var checkStatus = layuiTable.checkStatus("tabCommFun");
var filt;
if (checkStatus.data.length > 0) {
var CommId = "";
for (var i = 0; i < checkStatus.data.length; i++) {
CommId += checkStatus.data[i].CommID + ';';
}
CommId = CommId.substring(0, CommId.length - 1);
$("#modAddCommod").modal('hide');
tabTitles.reload({
url: "/OtherWorkManagement/StockAdjustment/SessSelecComm",
where: { CommId: CommId },
});
}
else {
layer.alert("请先选择商品!", { icon: 0 });
}
控制器:
—在控制器对从页面传递过来的ID字符串进行分割,在页面是以‘;’进行拼接,这里就根据‘;’进行分割,分割完之后就得到了多个单独的ID,将这些单独的ID放入一个字符串数组当中去!
string[] CommIDS = CommId.Split(’;’);
For循环上面的字符串数组,把里面的ID转换为数字的类型,再通过这个ID从数据库中查询出单条数据!
returnJson.State=false
List<CommoditsVo> listMarket = new List<CommoditsVo>();
for (int i = 0; i < CommIDS.Count(); i++)
{
var Commids = Convert.ToInt32(CommIDS[i]);
CommoditsVo dbCommits = (from tbCommits in myModels.B_Commodits
tbCommDeRe.UnitID equals tbUnits.UnitID
where tbCommits.CommID == Commids
select new CommoditsVo
{
CommID = tbCommits.CommID,
Catelist = tbCommDeRe.Catelist.Trim(),
FundsNum = tbCommits.FundsNum.Trim(),
Color = tbColor.ColorName.Trim(),
ToVoNo = tbCommits.ToVoNo,
ToSpecli = tbCommits.ToSpecli,
RegemId = tbCommDeRe.RegimenID,
}).Single();
–遍历上面的空的对象列表,通过里面的数据的ID和刚查询出来的这一条数据进行对比,如果它们的ID相同,声明对象列表中已经存在这一条数据,就把上面声明的一个bool类型的变量变成true,,并且跳出当前循环体(break)!
跳出当前循环体之后判断是否为false,如果为false说明对象列表中没有这一条数据,就把这一条数据添加到对象列表中,如果不为false说明对象中有这一条数据,改变它的状态值,并且查询开启一个新的循环(continue),这样就可以在选择数据时筛掉你所不需要的重复的数据了!
foreach (var item in listMarket)
{
if (item.CommID == dbCommits.CommID)
{
returnJson.State = true;
break;
}
}
if (returnJson.State==false)
{
listMarket.Add(dbCommits);
}
else
{
returnJson.State = false;
continue;
}
}
把对象列表变成到Session中去,在进行同样的操作时可以减少时间,提高效率!
Session[“listResult”] = listMarket;