迭代上半年项目数的列表
本文关键字:列表 项目数 上半年 迭代 | 更新日期: 2023-09-27 18:31:45
我正在尝试仅迭代前半项的列表,然后再次我想仅迭代列表的其余另一半的列表。有什么想法吗?
@foreach (var category in Model.Categories.OrderBy(i => i.CategoryName))
{
<li>
<div id="category_@(category.SKU)"
class="itemBlock"
onclick="toggle('@(category.SKU)')">
</li>
}
像这样:
var categories = Model.Categories.OrderBy(i => i.CategoryName).ToList();
int noOfCategories = categories.Count();
int half = noOfCategories/2;
for (int x = 0; x < half; x++)
{
var category = categories[x];
//your logic here
}
for (int x = half; x < noOfCategories; x++)
{
var category = categories[x];
//your logic here
}
应该做这个技巧,不能保证语法是 100%,但这应该给你你需要做的一切!
只需使用 for 循环。
for(int i=0; i < Model.Categories.OrderBy(i => i.CategoryName).Count/2; i++)
{
// do stuff
}
for(int i=Model.Categories.OrderBy(i => i.CategoryName).Count/2; i < Model.Categories.OrderBy(i => i.CategoryName).Count; i++)
{
// do different stuff
}
我真的建议将该逻辑推送到模型中,然后获取已为视图格式化的数据:
[Serializable]
public class YourModel
{
private int _mid
{
get { Categories.Count / 2; }
}
private int _top
{
get { Categories.Count - _mid; }
}
public List<Category> CategoriesLowerHalf
{
get { Categories.OrderBy(i => i.CategoryName).Take(_mid); }
}
public List<Category> CategoriesUpperHalf
{
get { Categories.OrderBy(i => i.CategoryName).GetRange(_mid, _top); }
}
// rest of your model
}
那么在您看来:
@foreach (var category in Model.CategoriesLowerHalf)
{
<li>
<div id="category_@(category.SKU)" class="itemBlock" onclick="toggle('@(category.SKU)')">category.Name</div>
</li>
}
@foreach (var category in Model.CategoriesUpperHalf)
{
<li>
<div id="category_@(category.SKU)" class="itemBlock" onclick="toggle('@(category.SKU)')">category.Name</div>
</li>
}
也许您可以将列表拆分为 2 个数组,然后根据需要对每个数组运行循环。
以下代码适用于我的应用程序。
@{
int a = 0;
int b = 0;
}
<li>
@foreach (var item in Model.NameHere)
{
//write code here
a++;
if (a == Model.Offices.Count() / 2)
{
break;
}
}
</li>
<li>
@foreach (var item in Model.NameHere)
{
if (b >= Model.Offices.Count() / 2)
{
//write code here
}
b++;
}
</li>