提取数据时筛掉重复的数据

本文介绍如何使用LayUI和JQuery处理表格数据,包括数据的选择、ID的拼接与传递,以及在控制器中对数据进行分割、转换和查询的方法。详细解释了从用户界面获取数据,到后端处理数据的全过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值