Почему я не могу выполнить foreach через свои ViewData или Model?

StackOverflow https://stackoverflow.com/questions/1441215

  •  10-07-2019
  •  | 
  •  

Вопрос

Я продолжаю получать ошибки при попытке перебрать мои ViewData в представлении...Я даже пытался настойчиво ввести представление в IEnumerable(App.Models.Namespace) и использовать Model, но безрезультатно.Либо я получаю сообщение об ошибке из-за отсутствия метода GetEnumerable, либо из-за неправильного приведения типов...Есть идеи, как мне это сделать?

Модель...

public IQueryable<Product> getAllProducts()
{
    return (from p in db.Products select p);
}

Контроллер...

public ActionResult Pricing()
{
    IQueryable<Product> products = orderRepository.getAllProducts();

    ViewData["products"] = products.ToList();

    return View();
}

Вид...

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    Pricing
</asp:Content>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

    <h2>Pricing</h2>

    <div>
        <select class="product">
            <%foreach(var prod in ViewData["products"]){%>
                <option><%=prod.Title %></option>
            <%} %>

        </select><select></select>
    </div>

</asp:Content>
Это было полезно?

Решение

Попробуйте это с актерским составом:

foreach(var prod in (List<Product>)ViewData["products"])

Другие советы

foreach (var prod in (ViewData["products"] as IEnumerable<Product>))

Я попал в аналогичную ситуацию, и это сработало для меня.

Почему ты вообще это делаешь?Почему бы не сделать:

Inherits="System.Web.Mvc.ViewPage<IEnumerable<Product>>

на ваш взгляд.Затем в действии вашего контроллера выполните:

public ActionResult Pricing()
{
    IQueryable<Product> products = orderRepository.getAllProducts();
    return View(products.ToList(););
}

Тогда вам не придется использовать ViewData совсем.

<%foreach(Product prod in ViewData["products"]){%>
foreach(var prod in ViewData["products"] as IQueryable<Product>)

Если вы получаете список из более чем двух моделей и хотите отобразить две модели в одном списке, вам следует использовать это.Создайте две модели: первая — «Ученик», вторая — «Учитель».

// Create Models
public class Student
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Address { get; set; }
    public List<int> Marks { get; set; }
}

public class Teacher
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string Address { get; set; }
}

//Создаем контроллер

  public ActionResult Index()
    {
        List<Student> students = new List<Student>()
        {
            new Student {Id = 1, Name = "Vikas", Address = "Mohali", Marks = new List<int> {90, 23, 46,56} },
            new Student {Id = 2, Name = "Rajeev", Address = "Mohali", Marks = new List<int> { 56, 78, 34, 67 }},
            new Student {Id = 3, Name = "Ajay", Address = "Delhi", Marks = new List<int> {56, 78, 34, 56}}
        };

        List<Teacher> teachers = new List<Teacher>()
        {
            new Teacher {Id = 1, Name = "Arun Nagar", Address = "Delhi"},
            new Teacher {Id = 2, Name = "Manish Kumar", Address = "Mohali"}
        };

        var Querylist = (from student in students
                         where student.Address == "Mohali"
                         select student.Name)
                        .Concat(from teacher in teachers
                                where teacher.Address == "Mohali"
                                select teacher.Name);
        //get list in ViewBag
        ViewBag.DataLIst = Querylist;
        //get list in View Data
        ViewData["DataLIst1"] = Querylist.ToList();
        return View(Querylist.AsEnumerable());
    }

//create View "Index.cshtml"   


@foreach (var h in @ViewBag.DataLIst)
{ 
    <h3>@h</h3>
}
@foreach (var s in @ViewData["DataLIst1"] as List< string>)
{
    <h1>@s</h1>
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top