以下代码适用于webform视图引擎。
<% Model.Categories.ForEach(x => { %>
<li><a href="#">@x.Name</a></li>
<% }) %>我在razor视图中编写了如下代码:
@Model.Categories.ForEach(x => {
<li><a href="#">@x.Name</a></li>
})但这不管用。
有没有人能建议,有没有办法在剃刀视图中实现这一点?
提前谢谢。
发布于 2011-03-13 12:44:49
谢谢你的帮助。基于Phil Haack的以下文章,我发现了如何在Razor中实现委托。Templated Razor Delegates
下面是IEnumerable的扩展代码:
public static HelperResult ForEachTemplate<TEntity>(
this IEnumerable<TEntity> items,
Func<RowEntity<TEntity>, HelperResult> template)
{
return new HelperResult(writer =>
{
var index = 0;
foreach (var item in items)
{
template(new RowEntity<TEntity> {
Index = index,
Value = item }).WriteTo(writer);
index++;
}
});
}
public class RowEntity<TEntity>
{
public int Index { get; set; }
public TEntity Value { get; set; }
}查看模型为:
// IEnumerable<Person>
public class Person
{
public string Name { get; set; }
}以及该扩展方法的使用:
@Model.ForEachTemplate(@<p>Index: @item.Index Name: @Item.Value.Name</p>)发布于 2011-02-22 19:06:12
你有什么理由需要这么做吗?
@foreach(var x in Model.Categories) {
<li><a href="#">@x.Name</a></li>
}上面做的是完全一样的事情,而且更加地道。
我看不到使用Razor语法输出.ForEach()委托结果的方法。Razor期望被调用的方法或被调用的属性返回一个值,然后将该值发送到视图输出。因为.ForEach()不返回任何内容,所以它不知道如何处理它:
不能显式地将类型'void‘转换为'object’
你可以让迭代器索引非常简洁,如下所示:
@foreach (var item in Model.Categories.Select((cat, i) => new { Item = cat, Index = i })) {
<li><a href="#">@x.Index - @x.Item.Name</a></li>
}如果您希望将其定义为扩展方法,而不是匿名类型,则可以创建一个类来保存Item, Index对,并在IEnumerable<T>上定义一个扩展方法,该方法yield包装在此构造中的原始enumerable中的项。
public static IEnumerable<IndexedItem<T>> WithIndex<T>(this IEnumerable<T> input)
{
int i = 0;
foreach(T item in input)
yield return new IndexedItem<T> { Index = i++, Item = item };
}类:
public class IndexedItem<T>
{
public int Index { get; set; }
public T Item { get; set; }
}用法:
@foreach(var x in Model.Categories.WithIndex()) {
<li><a href="#">@x.Index - @x.Item.Name</a></li>
}https://stackoverflow.com/questions/5077240
复制相似问题